use warnings; use strict; use DBI; use POSIX qw(strftime); my $currSysDate =strftime ("%m/%d/%Y", localtime); my $currYear =strftime("%Y", localtime); my $dbh; my $dsn = "dbi:Oracle:hod3"; my $user = 'dbo'; my $password = 'dbo'; my $mffundclass; my $mfstartdate; my $mfenddate; my $mfror; my $mdstartdate; my $mdenddate; my $mddiscountrate; if($currSysDate eq "06/29/$currYear"){ open ROR, ">>RORTableValues_Nav.txt" or die "Error in opening RORTableValues_Nav.txt"; open DISCOUNT, ">>DiscountRateTableValues_Nav.txt" or die "Error in opening DiscountRateTableValues_Nav.txt"; printf ROR ("MF_FUND_CLASS \t MF_START_DATE \t MF_END_DATE \t MF_ROR \n"); printf DISCOUNT ("MD_START_DATE \t MD_END_DATE \t MD_DISCOUNT_RATE \n"); $dbh = DBI->connect($dsn, $user, $password, {PrintError => 1, RaiseError => 1}) or die ("Can't execute statement: $DBI::errstr\n"); my $sql = qq{select * from T_LIMF_MRD_FUND_ROR}; my $sth = $dbh->prepare($sql); $sth->execute(); $sth->bind_columns(\$mffundclass,\$mfstartdate,\$mfenddate,\$mfror); while ($sth->fetch()){ print "$mffundclass \t $mfstartdate \t $mfenddate \t $mfror \n"; printf ROR "$mffundclass \t $mfstartdate \t $mfenddate \t $mfror \n"; }; $sth->finish(); my $sql1 = qq{select * from T_LIMD_MRD_DISCOUNT_RATE}; my $sth1 = $dbh->prepare($sql1); $sth1->execute(); $sth1->bind_columns(\$mdstartdate,\$mdenddate,\$mddiscountrate); while ($sth1->fetch()){ printf DISCOUNT "$mdstartdate \t $mdenddate \t $mddiscountrate \n"; }; $sth1->finish(); $dbh->disconnect(); }