English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
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
Ниже приведены важные программы DBI, которые могут удовлетворить ваши потребности в использовании базы данных SQLite в Perl-программах. Если вы хотите узнать больше细节, пожалуйста, посмотрите официальный документ Perl DBI.
Номер | API и описание |
---|---|
1 | DBI->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 с помощью создать и сделать установить для решения проблемы.
Ниже приведен 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 и отображает следующие строки:
База данных успешно открыта Записи успешно созданы
Ниже приведен 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 Операция выполнена успешно
Ниже приведен 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 Операция выполнена успешно
Ниже приведен 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 Операция выполнена успешно