Thread Multidimensionales Array mit Daten aus Datenbank füllen. (13 answers)
Opened by lordsirkendorf at 2009-09-16 14:55

lordsirkendorf
 2009-09-16 14:55
#125859 #125859
User since
2009-09-16
7 Artikel
BenutzerIn
[default_avatar]
Hallo Perl-Community,

vorweg sei gesagt, dass ich nicht nur ein absoluter Perl-Neuling bin, sondern auch generell auf dem Gebiet der Programmierung sehr unerfahren bin.

Ich habe auch schon das gefühlte halbe Internet nach einer Lösung für mein Problem durchforstet, bin aber leider nicht fündig geworden.

Jetzt aber zu meinem Problem:

Ich möchte die Daten einer Oracle Tabelle in ein Multidimensionales Array einlesen, sodass ich die einzelnen Felder anschließend gezielt ansprechen und weiterverarbeiten kann.
Die Tablle besteht aus 4 Spalten und 75 Zeilen. Mit dem untenstehenden Code kann ich mich mit der Datenbank verbinden und die Daten in ein Array einlesen. Ich kann mir mit print "@data\n"; die gesamte Tabelle ausgeben lassen und wie unten in meinem Code mit print "$data[0]\n"; die erste Spalte, mit print "$data[1]\n"; die zweite, usw.

Ich möchte aber dahin, dass ich mir mit print "$data[0]\n"; NUR das erste Feld der ersten Zeile ausgeben lassen kann. Mit print "$data[0][0][0][0]\n"; NUR das letzte Feld der ersten Zeile usw.

Ich hoffe, es ist einigermaßen verständlich, was ich bezwecken möchte. Für Eure Hilfe wäre ich Euch sehr dankbar - ich stehe kurz vor der Verzweiflung! Ich habe mir schon einige Tutorials und Forenbeiträge durchgelesen und schon einiges ausprobiert, aber nichts hat funktioniert.

Code: (dl )
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
#!/usr/bin/perl -w

use strict;
use DBI;

my $dbname = 'xxx'
my $user = 'xxxxxx'
my $passwd = 'xxxx'

my $dbh = DBI->connect('DBI:Oracle:$dbname', '$user', '$passwd')
or die "Couldn't connect to database: " . DBI->errstr;

my $sth = $dbh->prepare("select TABLESPACE_NAME, FILE_NAME, BYTES, MAXBYTES from dba_data_files where FILE_NAME like '%sapdata%' order by TABLESPACE_NAME")
or die "Couldn't prepare statement: " . $dbh->errstr;

my @data;

$sth->execute
or die "Couldn't execute statement: " . $sth->errstr;

while (@data = $sth->fetchrow_array) {
print "$data[0]\n";
}

$sth->finish;

$dbh->disconnect;

View full thread Multidimensionales Array mit Daten aus Datenbank füllen.