English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Основное руководство по SQLite

Дополнительное руководство по SQLite

Интерфейс программы SQLite

SQLite Perl

Установка

SQLite3 может быть интегрирован с Perl с помощью модуля Perl DBI. Модуль Perl DBI - это модуль доступа к базе данных для языков программирования Perl. Он определяет набор методов, переменных и правил, предоставляющих стандартный интерфейс к базе данных.

Ниже показаны простые шаги по установке модуля DBI на машинах Linux/UNIX:

$ 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

Если вам нужно установить драйвер SQLite для DBI, вы можете следовать следующим шагам для установки:

$ 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

API интерфейса DBI

Ниже приведены важные программы DBI, которые могут удовлетворить ваши потребности в использовании базы данных SQLite в Perl-программах. Если вы хотите узнать больше细节, пожалуйста, посмотрите официальный документ Perl DBI.

НомерAPI и описание
1DBI->connect($data_source, "", "", \%attr)

Установить соединение с базой данных или сеансом $data_source, запрашиваемым. Если соединение успешное, то возвращает объект обработки базы данных.

Формат источника данных выглядит следующим образом:DBI:SQLite:dbname='test.db'В этом случае, SQLite - это имя драйвера SQLite, а test.db - это имя файла базы данных SQLite. Если имя файла filename присвоить значение ':memory:'Если это так, то оно создаст базу данных в RAM, которая будет существовать только в течение времени действия сеанса.

Если имя файла filename является фактическим именем устройства файла, то будет использоваться этот параметр для попытки открыть файл базы данных. Если файла с таким именем не существует, будет создан новый файл базы данных с этим именем.

Вы можете оставить вторые и третьи параметры пустыми строками, последний параметр используется для передачи различных свойств, см. примеры ниже.

2$dbh->do($sql)

Эта процедура готовит и выполняет простое предложение SQL. Возвращает количество затронутых строк, если возникла ошибка, возвращает undef. Возврат значения -1 означает, что количество строк неизвестно, не применяется или недоступно. В данном случае $dbh - это объект обработки, возвращаемый вызовом DBI->connect().

3$dbh->prepare($sql)

Эта процедура готовит предложение для последующего выполнения базы данных и возвращает объект обработки предложения.

4$sth->execute()

Эта процедура выполняет все необходимые действия для выполнения подготовленного предложения. Возвращает undef при возникновении ошибки. Возвращает true при успешном выполнении, независимо от количества затронутых строк. В данном случае $sth - это объект обработки предложения, возвращаемый вызовом $dbh->prepare($sql).

5$sth->fetchrow_array()

Эта процедура��取 следующую строку данных и возвращает ее в виде списка значений полей. Поле Null возвращает значение undef.

6$DBI::err

Это эквивалент $h->err, где $h - это любой тип обработки, например $dbh, $sth или $drh. Программа возвращает код ошибки двигателя базы данных последнего вызванного метода драйвера.

7$DBI::errstr

Это эквивалент $h->errstr, где $h - это любой тип обработки, например $dbh, $sth или $drh. Программа возвращает сообщение об ошибке двигателя базы данных последнего вызванного метода DBI.

8$dbh->disconnect()

Эта процедура закрывает соединение с базой данных, открытое с помощью DBI->connect().

Подключение к базе данных

Следующий код Perl показывает, как подключиться к существующей базе данных. Если база данных не существует, она будет создана, и в конце вернется объект базы данных.

#!/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 "База данных успешно открыта\n";

Теперь запустим приведенный выше программу, чтобы создать нашу базу данных в текущем каталоге test.dbВы можете изменить путь по своему усмотрению. Сохраните приведенный выше код в файл sqlite.pl и выполните его, как показано ниже. Если база данных успешно создана, будет отображено следующее сообщение:

$ chmod +x sqlite.pl
$ ./sqlite.pl
Успешно открыта база данных

Создание таблицы

Ниже приведен фрагмент Perl-кода, который будет использоваться для создания таблицы в созданной ранее базе данных:

#!/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 "База данных успешно открыта\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 "Таблица создана успешно\n";
}
$dbh->disconnect();

Во время выполнения вышеуказанного скрипта он будет создавать в test.db Создайте таблицу COMPANY в ней и покажите сообщение, как показано ниже:

База данных успешно открыта
Таблица создана успешно

Внимание:Если вы встретите следующую ошибку в любом из операций:

Ошибка выполнения DBD::SQLite::st: не ошибка (21) в файле dbdimp.c на строке 398

в этом случае вы уже открыли доступный файл dbdimp.c в установке DBD-SQLite и нашли sqlite3_prepare() функцию, и изменить третий параметр с 0 на -1. В конце концов, установите DBD::SQLite с помощью создать и установить Установите DBD::SQLite, чтобы решить проблему. в этом случае у вас будет доступен файл dbdimp.c в установке DBD-SQLite, и вы найдете sqlite3_prepare() функцию и изменить третий аргумент на -1 вместо 0. В конце концов, установите DBD::SQLite с помощью создать и сделать установить для решения проблемы.

Операция INSERT

Ниже приведен Perl-скрипт, который показывает, как создать записи в таблице COMPANY, созданной ранее:

#!/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 "База данных успешно открыта\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 "Записи успешно созданы\n";
$dbh->disconnect();

При выполнении вышеуказанного программы, она создает данные в таблице COMPANY и отображает следующие строки:

База данных успешно открыта
Записи успешно созданы

Операция SELECT

Ниже приведен Perl-программа, которая показывает, как получить и отобразить записи из созданной ранее таблицы COMPANY:

#!/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 "База данных успешно открыта\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 "ИМЯ = ". $row[1] ."\n";
      print "АДРЕС = ". $row[2] ."\n";
      print "ЗАРПЛАТА = ". $row[3] ."\n\n";
}
print "Операция выполнена успешно\n";
$dbh->disconnect();

При выполнении программы она produces следующие результаты:

База данных успешно открыта
ИД = 1
ИМЯ = Пол
АДРЕС = Калифорния
ЗАРПЛАТА =  20000
ID = 2
NAME = Allen
ADDRESS = Texas
SALARY =  15000
ИД = 3
ИМЯ = Тедди
АДРЕС = Норвегия
ЗАРПЛАТА =  20000
ИД = 4
ИМЯ = Марк
АДРЕС = Rich-Mond
ЗАРПЛАТА =  65000
Операция выполнена успешно

Операция UPDATE

Ниже приведен Perl-код, который показывает, как использовать оператор UPDATE для обновления любой записи и затем получение и отображение обновленных записей из таблицы COMPANY:

#!/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 "База данных успешно открыта\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;
}
   print "Общее количество обновленных строк: $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 "ИМЯ = ". $row[1] ."\n";
      print "АДРЕС = ". $row[2] ."\n";
      print "ЗАРПЛАТА = ". $row[3] ."\n\n";
}
print "Операция выполнена успешно\n";
$dbh->disconnect();

При выполнении программы она produces следующие результаты:

База данных успешно открыта
Общее количество обновленных строк: 1
ИД = 1
ИМЯ = Пол
АДРЕС = Калифорния
ЗАРПЛАТА =  25000
ID = 2
NAME = Allen
ADDRESS = Texas
SALARY =  15000
ИД = 3
ИМЯ = Тедди
АДРЕС = Норвегия
ЗАРПЛАТА =  20000
ИД = 4
ИМЯ = Марк
АДРЕС = Rich-Mond
ЗАРПЛАТА =  65000
Операция выполнена успешно

Операция DELETE

Ниже приведен Perl-код, который показывает, как использовать оператор DELETE для удаления любой записи и затем получение и отображение оставшихся записей из таблицы COMPANY:

#!/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 "База данных успешно открыта\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;
}
   print "Общее количество удаленных строк: $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 "ИМЯ = ". $row[1] ."\n";
      print "АДРЕС = ". $row[2] ."\n";
      print "ЗАРПЛАТА = ". $row[3] ."\n\n";
}
print "Операция выполнена успешно\n";
$dbh->disconnect();

При выполнении программы она produces следующие результаты:

База данных успешно открыта
Общее количество удаленных строк: 1
ИД = 1
ИМЯ = Пол
АДРЕС = Калифорния
ЗАРПЛАТА =  25000
ИД = 3
ИМЯ = Тедди
АДРЕС = Норвегия
ЗАРПЛАТА =  20000
ИД = 4
ИМЯ = Марк
АДРЕС = Rich-Mond
ЗАРПЛАТА =  65000
Операция выполнена успешно