Ich habe folgendes Problem:Ich selektiere Daten aus einer Tabelle einer
Tabelle mit selectall_arrayref in $aref.
Das Skript läuft auf einem Webserver, die selektierten Daten sollen danach in eine Datei auf dem Webserver geschrieben werden.
Dazu benutze ich folgende sub:
#sub, um selektierte Daten in Datei zu #schreiben
sub write_data_to_dat{
my $i_dat_name = shift;
my $i_first_line = shift;
my $i_aref = shift; #array_ref von select
my $i_num_col = shift; #Anzahl der Spalten in $aref
my $l_row; #Zeile von $aref
my $l_line; #Zeile für die Datei
my $l; #Zählvariable
open(DATEI,">$i_dat_name")|| die "$c_e_no_open";
print DATEI $i_first_line;
for $l_row (@$i_aref){
$l_line = $l_row->[0];
$l = 1;
do {
$l_line = $l_line . "\t" . $l_row->[$l];
$l = $l + 1;
}until($l eq $i_num_col);
$l_line = $l_line . "\n";
print DATEI $l_line;
} #endfor
close(DATEI);
} #endsub
Es gibt 52 Spalten ($i_num_col).
Das Ganze funktioniert auch, aber die Performance beim Schreiben in die Datei ist absolut indiskutabel. So weit ich sehe, tritt das Problem bei Zeilen mit sehr vielen Initialwerten auf (Null auf der Datenbank)!
Kann mir jemand weiterhelfen?
Danke im Vorraus!
Antje
Datum: 16.12.2008-10:54
