SQLite - Perl
In diesem Kapitel erfahren Sie, wie Sie SQLite in Perl-Programmen verwenden.
Installation
SQLite3 kann mithilfe des Perl-DBI-Moduls, einem Datenbankzugriffsmodul für die Programmiersprache Perl, in Perl integriert werden. Es definiert eine Reihe von Methoden, Variablen und Konventionen, die eine Standarddatenbankschnittstelle bereitstellen.
Im Folgenden finden Sie einfache Schritte zum Installieren des DBI-Moduls auf Ihrem Linux / UNIX-Computer:
$ wget http://search.cpan.org/CPAN/authors/id/T/TI/TIMB/DBI-1.625.tar.gz
$ tar xvfz DBI-1.625.tar.gz
$ cd DBI-1.625
$ perl Makefile.PL
$ make
$ make install
Wenn Sie den SQLite-Treiber für DBI installieren müssen, kann er wie folgt installiert werden:
$ wget http://search.cpan.org/CPAN/authors/id/M/MS/MSERGEANT/DBD-SQLite-1.11.tar.gz
$ tar xvfz DBD-SQLite-1.11.tar.gz
$ cd DBD-SQLite-1.11
$ perl Makefile.PL
$ make
$ make install
DBI-Schnittstellen-APIs
Im Folgenden finden Sie wichtige DBI-Routinen, die für die Arbeit mit der SQLite-Datenbank Ihres Perl-Programms ausreichen können. Wenn Sie nach einer anspruchsvolleren Anwendung suchen, können Sie die offizielle Dokumentation von Perl DBI einsehen.
Sr.Nr. | API & Beschreibung |
---|---|
1 | DBI->connect($data_source, "", "", \%attr) Stellt eine Datenbankverbindung oder Sitzung zur angeforderten $ data_source her. Gibt ein Datenbankhandle-Objekt zurück, wenn die Verbindung erfolgreich ist. Datenquelle hat die Form wie - DBI:SQLite:dbname = 'test.db'Dabei ist SQLite der Name des SQLite-Treibers und test.db der Name der SQLite-Datenbankdatei. Wenn der Dateiname als angegeben ist':memory:'Es wird eine speicherinterne Datenbank im RAM erstellt, die nur für die Dauer der Sitzung gültig ist. Wenn der Dateiname der tatsächliche Name der Gerätedatei ist, wird versucht, die Datenbankdatei mithilfe ihres Werts zu öffnen. Wenn keine Datei mit diesem Namen vorhanden ist, wird eine neue Datenbankdatei mit diesem Namen erstellt. Sie behalten den zweiten und dritten Parameter als leere Zeichenfolgen bei, und der letzte Parameter besteht darin, verschiedene Attribute zu übergeben, wie im folgenden Beispiel gezeigt. |
2 | $dbh->do($sql) Diese Routine bereitet eine einzelne SQL-Anweisung vor und führt sie aus. Gibt die Anzahl der betroffenen oder bei einem Fehler nicht definierten Zeilen zurück. Ein Rückgabewert von -1 bedeutet, dass die Anzahl der Zeilen nicht bekannt, nicht zutreffend oder nicht verfügbar ist. Hier ist $ dbh ein Handle, das vom Aufruf DBI-> connect () zurückgegeben wird. |
3 | $dbh->prepare($sql) Diese Routine bereitet eine Anweisung für die spätere Ausführung durch das Datenbankmodul vor und gibt einen Verweis auf ein Anweisungshandle-Objekt zurück. |
4 | $sth->execute() Diese Routine führt die erforderliche Verarbeitung aus, um die vorbereitete Anweisung auszuführen. Ein undef wird zurückgegeben, wenn ein Fehler auftritt. Eine erfolgreiche Ausführung gibt unabhängig von der Anzahl der betroffenen Zeilen immer true zurück. Hier ist $ sth ein Anweisungshandle, das vom Aufruf $ dbh-> prepare ($ sql) zurückgegeben wird. |
5 | $sth->fetchrow_array() Diese Routine ruft die nächste Datenzeile ab und gibt sie als Liste mit den Feldwerten zurück. Nullfelder werden als undef-Werte in der Liste zurückgegeben. |
6 | $DBI::err Dies entspricht $ h-> err, wobei $ h einer der Handle-Typen wie $ dbh, $ sth oder $ drh ist. Dies gibt den Fehlercode des nativen Datenbankmoduls von der zuletzt aufgerufenen Treibermethode zurück. |
7 | $DBI::errstr Dies entspricht $ h-> errstr, wobei $ h einer der Handle-Typen wie $ dbh, $ sth oder $ drh ist. Dies gibt die native Datenbankmodul-Fehlermeldung der zuletzt aufgerufenen DBI-Methode zurück. |
8 | $dbh->disconnect() Diese Routine schließt eine Datenbankverbindung, die zuvor durch einen Aufruf von DBI-> connect () geöffnet wurde. |
Verbindung zur Datenbank herstellen
Der folgende Perl-Code zeigt, wie Sie eine Verbindung zu einer vorhandenen Datenbank herstellen. Wenn die Datenbank nicht vorhanden ist, wird sie erstellt und schließlich wird ein Datenbankobjekt zurückgegeben.
#!/usr/bin/perl
use DBI;
use strict;
my $driver = "SQLite";
my $database = "test.db";
my $dsn = "DBI:$driver:dbname=$database";
my $userid = "";
my $password = "";
my $dbh = DBI->connect($dsn, $userid, $password, { RaiseError => 1 })
or die $DBI::errstr;
print "Opened database successfully\n";
Führen Sie nun das obige Programm aus, um unsere Datenbank test.db im aktuellen Verzeichnis zu erstellen. Sie können Ihren Pfad gemäß Ihren Anforderungen ändern. Behalten Sie den obigen Code in der Datei sqlite.pl bei und führen Sie ihn wie unten gezeigt aus. Wenn die Datenbank erfolgreich erstellt wurde, wird die folgende Meldung angezeigt:
$ chmod +x sqlite.pl
$ ./sqlite.pl
Open database successfully
Erstellen Sie eine Tabelle
Das folgende Perl-Programm wird verwendet, um eine Tabelle in der zuvor erstellten Datenbank zu erstellen.
#!/usr/bin/perl
use DBI;
use strict;
my $driver = "SQLite";
my $database = "test.db";
my $dsn = "DBI:$driver:dbname=$database";
my $userid = "";
my $password = "";
my $dbh = DBI->connect($dsn, $userid, $password, { RaiseError => 1 })
or die $DBI::errstr;
print "Opened database successfully\n";
my $stmt = qq(CREATE TABLE COMPANY
(ID INT PRIMARY KEY NOT NULL,
NAME TEXT NOT NULL,
AGE INT NOT NULL,
ADDRESS CHAR(50),
SALARY REAL););
my $rv = $dbh->do($stmt);
if($rv < 0) {
print $DBI::errstr;
} else {
print "Table created successfully\n";
}
$dbh->disconnect();
Wenn das obige Programm ausgeführt wird, erstellt es eine COMPANY-Tabelle in Ihrer test.db und zeigt die folgenden Meldungen an:
Opened database successfully
Table created successfully
NOTE - Falls bei einer Operation der folgende Fehler auftritt -
DBD::SQLite::st execute failed: not an error(21) at dbdimp.c line 398
In diesem Fall öffnen dbdimp.c file verfügbar in der DBD-SQLite-Installation und finden Sie es heraus sqlite3_prepare() Funktion und ändern Sie das dritte Argument in -1 statt 0. Installieren Sie abschließend DBD :: SQLite mit make und TU make install um das Problem zu lösen.
INSERT-Betrieb
Das folgende Perl-Programm zeigt, wie Datensätze in der im obigen Beispiel erstellten COMPANY-Tabelle erstellt werden.
#!/usr/bin/perl
use DBI;
use strict;
my $driver = "SQLite";
my $database = "test.db";
my $dsn = "DBI:$driver:dbname=$database";
my $userid = "";
my $password = "";
my $dbh = DBI->connect($dsn, $userid, $password, { RaiseError => 1 })
or die $DBI::errstr;
print "Opened database successfully\n";
my $stmt = qq(INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (1, 'Paul', 32, 'California', 20000.00 ));
my $rv = $dbh->do($stmt) or die $DBI::errstr;
$stmt = qq(INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (2, 'Allen', 25, 'Texas', 15000.00 ));
$rv = $dbh->do($stmt) or die $DBI::errstr;
$stmt = qq(INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (3, 'Teddy', 23, 'Norway', 20000.00 ));
$rv = $dbh->do($stmt) or die $DBI::errstr;
$stmt = qq(INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00 ););
$rv = $dbh->do($stmt) or die $DBI::errstr;
print "Records created successfully\n";
$dbh->disconnect();
Wenn das obige Programm ausgeführt wird, werden die angegebenen Datensätze in der COMPANY-Tabelle erstellt und die folgenden zwei Zeilen angezeigt:
Opened database successfully
Records created successfully
SELECT-Betrieb
Das folgende Perl-Programm zeigt, wie Datensätze aus der im obigen Beispiel erstellten COMPANY-Tabelle abgerufen und angezeigt werden.
#!/usr/bin/perl
use DBI;
use strict;
my $driver = "SQLite";
my $database = "test.db";
my $dsn = "DBI:$driver:dbname=$database";
my $userid = "";
my $password = "";
my $dbh = DBI->connect($dsn, $userid, $password, { RaiseError => 1 })
or die $DBI::errstr;
print "Opened database successfully\n";
my $stmt = qq(SELECT id, name, address, salary from COMPANY;);
my $sth = $dbh->prepare( $stmt );
my $rv = $sth->execute() or die $DBI::errstr;
if($rv < 0) {
print $DBI::errstr;
}
while(my @row = $sth->fetchrow_array()) {
print "ID = ". $row[0] . "\n";
print "NAME = ". $row[1] ."\n";
print "ADDRESS = ". $row[2] ."\n";
print "SALARY = ". $row[3] ."\n\n";
}
print "Operation done successfully\n";
$dbh->disconnect();
Wenn das obige Programm ausgeführt wird, wird das folgende Ergebnis erzeugt.
Opened database successfully
ID = 1
NAME = Paul
ADDRESS = California
SALARY = 20000
ID = 2
NAME = Allen
ADDRESS = Texas
SALARY = 15000
ID = 3
NAME = Teddy
ADDRESS = Norway
SALARY = 20000
ID = 4
NAME = Mark
ADDRESS = Rich-Mond
SALARY = 65000
Operation done successfully
UPDATE-Betrieb
Der folgende Perl-Code zeigt, wie die UPDATE-Anweisung zum Aktualisieren eines Datensatzes und zum Abrufen und Anzeigen der aktualisierten Datensätze aus der COMPANY-Tabelle ausgeführt wird.
#!/usr/bin/perl
use DBI;
use strict;
my $driver = "SQLite";
my $database = "test.db";
my $dsn = "DBI:$driver:dbname=$database";
my $userid = "";
my $password = "";
my $dbh = DBI->connect($dsn, $userid, $password, { RaiseError => 1 })
or die $DBI::errstr;
print "Opened database successfully\n";
my $stmt = qq(UPDATE COMPANY set SALARY = 25000.00 where ID=1;);
my $rv = $dbh->do($stmt) or die $DBI::errstr;
if( $rv < 0 ) {
print $DBI::errstr;
} else {
print "Total number of rows updated : $rv\n";
}
$stmt = qq(SELECT id, name, address, salary from COMPANY;);
my $sth = $dbh->prepare( $stmt );
$rv = $sth->execute() or die $DBI::errstr;
if($rv < 0) {
print $DBI::errstr;
}
while(my @row = $sth->fetchrow_array()) {
print "ID = ". $row[0] . "\n";
print "NAME = ". $row[1] ."\n";
print "ADDRESS = ". $row[2] ."\n";
print "SALARY = ". $row[3] ."\n\n";
}
print "Operation done successfully\n";
$dbh->disconnect();
Wenn das obige Programm ausgeführt wird, wird das folgende Ergebnis erzeugt.
Opened database successfully
Total number of rows updated : 1
ID = 1
NAME = Paul
ADDRESS = California
SALARY = 25000
ID = 2
NAME = Allen
ADDRESS = Texas
SALARY = 15000
ID = 3
NAME = Teddy
ADDRESS = Norway
SALARY = 20000
ID = 4
NAME = Mark
ADDRESS = Rich-Mond
SALARY = 65000
Operation done successfully
DELETE-Betrieb
Der folgende Perl-Code zeigt, wie Sie mit der DELETE-Anweisung einen Datensatz löschen und dann die verbleibenden Datensätze aus der COMPANY-Tabelle abrufen und anzeigen.
#!/usr/bin/perl
use DBI;
use strict;
my $driver = "SQLite";
my $database = "test.db";
my $dsn = "DBI:$driver:dbname=$database";
my $userid = "";
my $password = "";
my $dbh = DBI->connect($dsn, $userid, $password, { RaiseError => 1 })
or die $DBI::errstr;
print "Opened database successfully\n";
my $stmt = qq(DELETE from COMPANY where ID = 2;);
my $rv = $dbh->do($stmt) or die $DBI::errstr;
if( $rv < 0 ) {
print $DBI::errstr;
} else {
print "Total number of rows deleted : $rv\n";
}
$stmt = qq(SELECT id, name, address, salary from COMPANY;);
my $sth = $dbh->prepare( $stmt );
$rv = $sth->execute() or die $DBI::errstr;
if($rv < 0) {
print $DBI::errstr;
}
while(my @row = $sth->fetchrow_array()) {
print "ID = ". $row[0] . "\n";
print "NAME = ". $row[1] ."\n";
print "ADDRESS = ". $row[2] ."\n";
print "SALARY = ". $row[3] ."\n\n";
}
print "Operation done successfully\n";
$dbh->disconnect();
Wenn das obige Programm ausgeführt wird, wird das folgende Ergebnis erzeugt.
Opened database successfully
Total number of rows deleted : 1
ID = 1
NAME = Paul
ADDRESS = California
SALARY = 25000
ID = 3
NAME = Teddy
ADDRESS = Norway
SALARY = 20000
ID = 4
NAME = Mark
ADDRESS = Rich-Mond
SALARY = 65000
Operation done successfully