воскресенье, 31 марта 2019 г.

Код ошибки: 1062. Дублируемая запись 'PRIMARY'

mysql ошибка 1062

Код ошибки: 1062. Дублируемая запись 'PRIMARY'


Итак, мой профессор дал мне таблицы, чтобы вставить их в базу данных, но когда я выполняю его код, MySQL постоянно дает код ошибки: 1062. Ниже приведены таблицы конфликтов и вставки:
ТАБЛИЦЫ
CREATE TABLE FABRICANTES(
COD_FABRICANTE integer NOT NULL,
NOMBRE         VARCHAR(15), 
PAIS           VARCHAR(15),
primary key (cod_fabricante)
);

CREATE TABLE ARTICULOS(
ARTICULO       VARCHAR(20)NOT NULL,
COD_FABRICANTE integer NOT NULL,
PESO           integer NOT NULL ,
CATEGORIA      VARCHAR(10) NOT NULL,
PRECIO_VENTA   integer,
PRECIO_COSTO   integer,
EXISTENCIAS    integer,
primary key (articulo,cod_fabricante),
foreign key (cod_fabricante) references Fabricantes(cod_fabricante)
);
ВСТАВИТЬ В:
INSERT INTO FABRICANTES VALUES(10,'CALVO', 'ESPAÑA');
INSERT INTO FABRICANTES VALUES(15,'LU', 'BELGICA');
INSERT INTO FABRICANTES VALUES(20,'BARILLA', 'ITALIA');
INSERT INTO FABRICANTES VALUES(25,'GALLO', 'ESPAÑA');
INSERT INTO FABRICANTES VALUES(30,'PRESIDENT', 'FRANCIA');

INSERT INTO ARTICULOS VALUES ('Macarrones',20, 1, 'Primera',100,98,120);
INSERT INTO ARTICULOS VALUES ('Tallarines',20, 2, 'Primera',120,100,100);
INSERT INTO ARTICULOS VALUES ('Tallarines',20, 1, 'Segunda',99,50,100);
INSERT INTO ARTICULOS VALUES ('Macarrones',20, 1, 'Tercera',80,50,100);
INSERT INTO ARTICULOS VALUES ('Atún',10, 3, 'Primera',200,150,220);
INSERT INTO ARTICULOS VALUES ('Atún',10, 3, 'Segunda',150,100,220);
INSERT INTO ARTICULOS VALUES ('Atún',10, 3, 'Tercera',100,50,220);
INSERT INTO ARTICULOS VALUES ('Sardinillas',10, 1,'Primera',250,200,200);
INSERT INTO ARTICULOS VALUES ('Sardinillas',10, 1,'Segunda',200,160,200);
INSERT INTO ARTICULOS VALUES ('Sardinillas',10, 1,'Tercera',100,150,220);
INSERT INTO ARTICULOS VALUES ('Mejillones',10, 1, 'Tercera',90,50,200);
INSERT INTO ARTICULOS VALUES ('Mejillones',10, 1, 'Primera',200,150,300);
INSERT INTO ARTICULOS VALUES ('Macarrones',25, 1, 'Primera',90,68,150);
INSERT INTO ARTICULOS VALUES ('Tallarines',25, 1, 'Primera',100,90,100);
INSERT INTO ARTICULOS VALUES ('Fideos',25, 1, 'Segunda',75,50,100);
INSERT INTO ARTICULOS VALUES ('Fideos',25, 1, 'Primera',100,80,100);
INSERT INTO ARTICULOS VALUES ('Galletas Cuadradas',15, 1, 'Primera',100,80,100);
INSERT INTO ARTICULOS VALUES ('Galletas Cuadradas',15, 1, 'Segunda',70,50,100);
INSERT INTO ARTICULOS VALUES ('Galletas Cuadradas',15, 1, 'Tercera',50,40,100);
INSERT INTO ARTICULOS VALUES ('Barquillos',15, 1, 'Primera',100,80,100);
INSERT INTO ARTICULOS VALUES ('Barquillos',15, 1, 'Segunda',100,80,100);
INSERT INTO ARTICULOS VALUES ('Canutillos',15, 2, 'Primera',170,150,110);
INSERT INTO ARTICULOS VALUES ('Canutillos',15, 2, 'Segunda',120,150,110);
INSERT INTO ARTICULOS VALUES ('Leche entera',30, 1, 'Primera',110,100,300);
INSERT INTO ARTICULOS VALUES ('Leche desnat.',30, 1, 'Primera',120,100,300);
INSERT INTO ARTICULOS VALUES ('Leche semi.',30, 1, 'Primera',130,110,300);
INSERT INTO ARTICULOS VALUES ('Leche entera',30, 2, 'Primera',210,200,300);
INSERT INTO ARTICULOS VALUES ('Leche desnat.',30, 2, 'Primera',220,200,300);
INSERT INTO ARTICULOS VALUES ('Leche semi.',30, 2, 'Primera',230,210,300);
INSERT INTO ARTICULOS VALUES ('Mantequilla',30, 1, 'Primera',510,400,200);
INSERT INTO ARTICULOS VALUES ('Mantequilla',30, 1, 'Segunda',450,340,200);
ОШИБКА:
Error Code: 1062. Duplicate entry 'Macarrones-20' for key 'PRIMARY'
Если я удалю эту строку, я получаю ту же ошибку, но с "Tallarines-20"
Извините, если есть ошибка заклинания. Спасибо!
Вы пытаетесь вставить две строки с одним и тем же основным ключом.
INSERT INTO ARTICULOS VALUES ('Tallarines',20, 2, 'Primera',120,100,100);
INSERT INTO ARTICULOS VALUES ('Tallarines',20, 1, 'Segunda',99,50,100);
Вам, вероятно, нужно добавить CATEGORIA в ваш первичный ключ для таблицы ARTICULOS, потому что вы пытаетесь вставить несколько строк с одним и тем же основным ключом несколько раз.
primary key (articulo,cod_fabricante, categoria)Этот код ошибки 1062 происходит из-за дублирования записи. Вы пытаетесь вставить значение, которое уже существует в поле первичного ключа. Недавно я решил эту проблему, добавив auto_increment в поле первичного ключа. Я выполнил исправление, приведенное в этом сообщении как решить код ошибки mysql: 10У меня была такая же ошибка при попытке установить столбец в качестве первичного ключа. Я просто удалил столбец и воссоздал его, что позволило мне назначить его в качестве первичного ключа. Это также устраняет ошибку # 1075, где требуется, чтобы столбец автоматического инкремента был ключом (если вы попытаетесь установить столбец для автоматического увеличения).
7 и 8th INSERT равны. Вы не можете ввести более одной строки с одним и тем же основным ключом. Обратите внимание, что ваш первичный ключ - это набор: (articulate, cod_fabricante), поэтому любая строка с теми же articulate и cod_fabricante будет генерировать ошибку 1062.
INSERT INTO ARTICULOS VALUES ('Tallarines',20, 2, 'Primera',120,100,100);
INSERT INTO ARTICULOS VALUES ('Tallarines',20, 1, 'Segunda',99,50,100);
Удалите одну из строк или измените первичный ключ одного из нихУ вас есть ошибка дублирующего ключа во второй таблице ARTICULOS. у вас есть первичный ключ с комбинацией из двух столбцов (articulo, cod_fabricante).
Таким образом, все строки однозначно определяются в комбинации этих столбцов. удалите повторяющиеся строки из второй таблицы или замените первичный ключ.

понедельник, 4 марта 2019 г.

MySQL error 1045

Ошибка MySQL 1045


Автор: Василий Лукьянчиков , vl (at) sqlinfo (dot) ru
Статистика форума SQLinfo показывает, что одной из наиболее популярных проблем является ошибка mysql №1045 (ошибка доступа). 
Текст ошибки содержит имя пользователя, которому отказано в доступе, компьютер, с которого производилось подключение, а также ключевое слово YES или NO, которые показывают использовался ли при этом пароль или была попытка выполнить подключение с пустым паролем.
Типичные примеры:
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES) -- сервер MySQL
-- сообщает, что была неудачная попытка подключения с локальной машины пользователя с именем root и
-- не пустым паролем.
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO) -- отказано в 
-- доступе с локальной машины пользователю с именем root при попытке подключения с пустым паролем.
ERROR 1045 (28000): Access denied for user 'ODBC'@'localhost' (using password: NO) -- отказано в 
-- доступе с локальной машины пользователю с именем ODBC при попытке подключения с пустым паролем.

Причина возникновения ошибки 1045

Как ни банально, но единственная причина это неправильная комбинация пользователя и пароля. Обратите внимание, речь идет о комбинации пользователь и пароль, а не имя пользователя и пароль. Это очень важный момент, так как в MySQL пользователь характеризуется двумя параметрами: именем и хостом, с которого он может обращаться. Синтаксически записывается как 'имя пользователя'@'имя хоста'.
Таким образом, причина возникновения MySQL error 1045 - неправильная комбинация трех параметров: имени пользователя, хоста и пароля.
В качестве имени хоста могут выступать ip адреса, доменные имена, ключевые слова (например, localhost для обозначения локальной машины) и групповые символы (например, % для обозначения любого компьютера кроме локального). Подробный синтаксис смотрите в документации
Замечание: Важно понимать, что в базе не существует просто пользователя с заданным именем (например, root), а существует или пользователь с именем root, имеющий право подключаться с заданного хоста (например, root@localhost) или даже несколько разных пользователей с именем root (root@127.0.0.1, root@webew.ru, root@'мой домашний ip' и т.д.) каждый со своим паролем и правами.
Примеры.
1) Если вы не указали в явном виде имя хоста
ПРЕДОСТАВЛЯЙТЕ ВСЕ  НА ПУБЛИКАЦИЯХ  . *  ДЛЯ  'ODBC'  ИДЕНТИФИЦИРОВАНО  'Newpass' ;
то у вас будет создан пользователь 'ODBC'@'%' и при попытке подключения с локальной машины вы получите ошибку:
ОШИБКА  1045  ( 28000 ) : доступ запрещен для пользователя  'ODBC' @ 'localhost'  ( с использованием  пароля: ДА )
так как пользователя 'ODBC'@'localhost' у вас не существует.
2) Другой первопричиной ошибки mysql 1045 может быть неправильное использование кавычек.
CREATE USER 'new_user@localhost' IDENTIFIED BY 'mypass'-- будет создан пользователь 'new_user@localhost'@'%'
Правильно имя пользователя и хоста нужно заключать в кавычки отдельно, т.е. 'имя пользователя'@'имя хоста'
3) Неочевидный вариант. IP адрес 127.0.0.1 в имени хоста соответствует ключевому слову localhost. С одной стороны, root@localhost и 'root'@'127.0.0.1' это синонимы, с другой, можно создать двух пользователей с разными паролями. И при подключении будет выбран тот, который распологается в таблице привелегий (mysql.user) раньше.
4) Аккаунт с пустым именем пользователя трактуется сервером MySQL как анонимный, т.е. позволяет подключаться пользователю с произвольным именем или без указания имени. Например, вы создали пользователя ''@localhost с пустым паролем, чтобы каждый мог подключиться к базе. Однако, если при подключении вы укажите пароль отличный от пустого, то получите ошибку 1045. Как говорилось ранее, нужно совпадение трех параметров: имени пользователя, хоста и пароля, а пароль в данном случае не совпадает с тем, что в базе.

Что делать?

Во-первых, нужно убедиться, что вы используете правильные имя пользователя и пароль. Для этого нужно подключиться к MySQL с правами администратора (если ошибка 1045 не дает такой возможности, то нужно перезапустить сервер MySQL в режиме --skip-grant-tables), посмотреть содержимое таблицы user служебной базы mysql, в которой хранится информация о пользователях, и при необходимости отредактировать её.
Пример.
ВЫБЕРИТЕ  пользователя, хост, пароль ОТ mysql.user; + -----------
---- + ----------------- + --------------- ---------------------------- + | пользователь | хозяин | пароль | + --------------- + ----------------- + --------------- ---------------------------- + | корень | дом-f26710394 | * 81F5E21E35407D884A6CD4A731AEBFB6AF209E1B | | аа | местный хост | * 196BDEDE2AE4F84CA44C47D54D78478C7E2BD7B7 | | тест | местный хост | | | new_user | % | | | | % | * D7D6F58029EDE62070BA204436DE23AC54D8BD8A |  
| новый @ localhost | % | * ADD102DFD6933E93BCAD95E311360EC45494AA6E |
| корень | местный хост | * 81F5E21E35407D884A6CD4A731AEBFB6AF209E1B |
+ --------------- + ----------------- + --------------- ---------------------------- +
Если изначально была ошибка:
  • ОШИБКА 1045 ( 28000 ) : доступ запрещен для пользователя 'root' @ 'localhost' ( с использованием пароля: ДА )     
    значит вы указывали при подключении неверный пароль, так как пользователь root@localhost существует. Сам пароль храниться в зашифрованном виде и его нельзя узнать, можно лишь задать новый
    SET PASSWORD FOR root@localhost=PASSWORD('новый пароль');
  • ОШИБКА 1045 ( 28000 ) : доступ запрещен для пользователя 'ODBC' @ 'localhost' ( с использованием пароля: ДА )     
    в данном случае в таблице привилегий отсутствует пользователь 'ODBC'@'localhost'. Его нужно создать, используя команды GRANT, CREATE USER и SET PASSWORD.
Экзотический пример. Устанавливаете новый пароль для root@localhost в режиме --skip-grant-tables, однако после перезагрузки сервера по прежнему возникает ошибка при подключении через консольный клиент:
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES) Оказалось, что было установлено два сервера MySQL, настроенных на один порт.

PHPMyAdmin

При открытии в браузере phpmyadmin получаете сообщение:
Ошибка
MySQL  говорит: # 1045 - Доступ запрещен для пользователя 'root' @ 'localhost' (с использованием пароля: НЕТ). Соединение для controluser, как определено в вашей конфигурации, не удалось. phpMyAdmin попытался подключиться к серверу MySQL , и сервер отклонил соединение. Вы должны проверить хост, имя пользователя и пароль в вашей конфигурации и убедиться, что они соответствуют информации, предоставленной администратором сервера MySQL .


     
    
Ни логина, ни пароля вы не вводили, да и пхпадмин их нигде требовал, сразу выдавая сообщение об ошибке. Причина в том, что данные для авторизации берутся из конфигурационного файла config.inc.php Необходимо заменить в нем строчки
$ cfg [ 'Servers' ] [ $ i ] [ 'user' ]  = 'root' ;      // MySQL user $ cfg [ 'Servers' ] [ $ i ] [ 'password' ] = '' ;      // Пароль MySQL (нужен только 
  

на

$cfg['Servers'][$i]['user'] = 'ЛОГИН';    
$cfg['Servers'][$i]['password'] = 'ПАРОЛЬ'

Установка новой версии

Устанавливаете новую версию MySQL, но в конце при завершении конфигурации выпадает ошибка:
ОШИБКА Nr. 1045 Доступ запрещен для пользователя 'root' @ 'localhost' ( используется пароль: НЕТ ) 
   
Это происходит потому, что ранее у вас стоял MySQL, который вы удалили без сноса самих баз. Если вы не помните старый пароль и вам нужны эти данные, то выполните установку новой версии без смены пароля, а потом смените пароль вручную через режим --skip-grant-tables.
P.S. Статья написана по материалам форума SQLinfo, т.е. в ней описаны не все потенциально возможные случаи возникновения ошибки mysql №1045, а только те, что обсуждались на форуме. Если ваш случай не рассмотрен в статье, то задавайте вопрос на форуме SQLinfo
Вам ответят, а статья будет расширена.

вторник, 12 февраля 2019 г.

Работа с SQLite

Работа с SQLite

Автор: Гончаров А.Н.

Введение

SQLite – это реляционная база данных, запросы к которой можно осуществлять при помощи языка запросов SQL. База данных не поддерживает все особенности SQL и уступает в функциональности другим развитым СУБД, но вполне подходит для хранения и извлечения информации.

Отличие SQLite от MySQL и аналогичных СУБД

Классические СУБД, такие как MySQL (а так же MS SQL, Oracle, PostgreeSQL) состоят из отдельного сервера, поддерживающего работу базы данных и прослушивающих определённый порт, на предмет обращения клиентов. В качестве клиента может выступать в том числе и расширение PHP, реализующего интерфейс, с помощью которого осуществляются запросы к базе. Движок SQLite и интерфейс к ней реализованы в одной библиотеке, что увеличивает скорость выполнения запросов. Такой сервер часто называют встроенным.

Замечание

Встроенный сервер имеется и у других баз данных, например, у MySQL, но его использование требует лицензионных отчислений, поэтому не получило широкое распространение в мире открытых исходных кодов.
SQLite является бестиповой базой данных. Точнее, есть только два типа – целочисленный "integer" и текстовый "text". Причём "integer" используется преимущественно для первичного ключа таблицы, а для остальных данных пойдёт "text". Длина строки, записываемой в текстовое поле, может быть любой.

Особенности SQLite

Все базы данных хранятся в файлах, по одному файлу на базу. Количество баз данных, а так же таблиц в них, ограниченно только свободным местом, имеющимся на сайте. А максимально возможный объём одной базы данных составляет 2 Тб.
Так как все данные хранятся в файлах, проблем с переносом базы данных с одного хостинга на другой не существует – достаточно лишь скопировать соответствующие файлы.

Установка SQLite

В PHP5 поддержка SQLite установлена и включена по умолчанию.
Установка под Windows: Для установки SQLite необходимо скачать и скопировать в папку с расширениями библиотеку "php_sqlite.dll", которую можно загрузить по ссылке: http://snaps.php.net/win32/PECL_STABLE/php_sqlite.dll. Затем необходимо раскомментировать (или добавить) строку "extension=php_sqlite.dll" в файле "php.ini". Для нормального функционирования SQLite также необходимо раскомментировать строку "extension=php_pdo.dll".

Замечание

Если используется полная версия PHP в zip-архиве, а не в виде инсталлятора, соответствующие библиотеки расширения должны находится в директории расширений PECL.

Замечание

Библиотека "php_pdo.dll" должна загружаться до загрузки "php_sqlite.dll". То есть в php.ini строка "extension=php_sqlite.dll" должна стоять после "extension=php_pdo.dll".
Установка под Unix: Скачайте свежую версию SQLite с официального сайта (http://sqlite.org/download.html). Прочтите файл "INSTALL", поставляемый с исходными тестами модуля. Или просто воспользуйтесь командой установки PEAR: "pear install sqlite".

Работа с SQLite

Создание базы данных: Для того чтобы создать новую базу данных необходимо воспользоваться функцией sqlite_open(). Если базы, имя которой указано в параметре "filename" не существует, то функция создаст новую базу данных с именем "filename" и вернёт идентификатор базы данных.
resource sqlite_open ( string filename [, int mode [, string &error_message]] )
В скрипте, преведённом ниже, демонстрируется создание новой базы данных:
<?php
  
// Создадим базу данных
  
$db sqlite_open("my_database.db");
  if (!
$db) exit("Не удалось создать базу данных!"); ?>
В результате в папке со скриптом у нас появится файл с именем "my_database.db" – наша база данных.
Создание таблиц: Все запросы к базе данных выполняет функция sqlite_query(), которая имеет следующий синтаксис:
resource sqlite_query ( resource dbhandle, string query )

Замечание

Для работы с SQLite, как и любой реляционной базой данных используется язык запросов SQL. Поэтому создать таблицу данных можно при помощи традиционного запроса CREATE TABLE, вставить запись при помощи оператора INSERT, извлечь запись при помощи SELECT, а обновить существующую запись при помощи запроса UPDATE.
В приведённом ниже примере создаётся таблица table1, содержащая три поля: целочисленное поле id, которое выступает в качестве первичного ключа, и два текстовых поля field1 и field2.
<?php
  
// Создадим новую базу данных
  
$db sqlite_open("my_database.db");
  if (!
$db) exit("Невозможно создать базу данных!");
  
// Создадим таблицу "table1" в базе
  
$query_table sqlite_query($db"CREATE TABLE table1
                              (id INTEGER PRIMARY KEY,
                              /* id автоматически станет автоинкрементным */
                               field1 TEXT,
                               field2 TEXT);
                              "
);
  if (!
$query_table) exit("Невозможно создать таблицу в базе данных!");
  
// Запишем что-нибудь в таблицу
  
$query_insert sqlite_query($db"INSERT INTO table1(field1, field2) VALUES ('PHP5', 'Apache');");
  if (!
$query_insert) exit("Невозможно записать данные в таблицу!"); ?>
После создания таблицы, в неё добавляется запись, содержащая строки 'PHP5' и 'Apache', поле id автоматически получает значение 1.
Вывод данных из базы: Для вывода данных из таблиц используется всё та же функция – sqlite_query(). Если выбирается несколько записей, результат выборки следует обработать при помощи цикла while() и функции sqlite_fetch_array(), которая имеет следующий синтаксис:
array sqlite_fetch_array ( resource result [, int result_type [, bool decode_binary]] )
Ниже приводится скрипт, демонстрирующий вывод нескольких записей из базы данных:
<?php
  
// Создадим новую базу данных
  
$db sqlite_open("my_database.db");
  if (!
$db) exit("Невозможно создать базу данных!");
  
// Создадим таблицу "table1" в базе
  
$query_table sqlite_query($db"CREATE TABLE table1
                              (id INTEGER PRIMARY KEY,
                               /* id автоматически станет автоинкрементным */
                               field1 TEXT,
                               field2 TEXT);
                              "
);
  if (!
$query_table) exit("Невозможно создать таблицу в базе данных!");
  
// Запишем что-нибудь в таблицу
  
sqlite_query($db"INSERT INTO table1(field1, field2) VALUES ('PHP5+', 'Apache');");
  
sqlite_query($db"INSERT INTO table1(field1, field2) VALUES ('SQLite – ', 'классная вещь');");
  
sqlite_query($db"INSERT INTO table1(field1, field2) VALUES ('Посетите ', 'sqlite.org');");
  
// Сделаем выборку данных
  
$res sqlite_query($db"SELECT * FROM table1;");
  
// В цикле выведем все полученные данные
  
while ($array sqlite_fetch_array($res))
  {
    echo(
$array['field1'].$array['field2']." (id записи:".$array['id'].")<br />");
  } 
?>
В результате работы скрипта получим:
PHP5+Apache (id записи:1)
SQLite – классная вещь (id записи:2)
посетите sqlite.org (id записи:3)
Редактрирование записи: Для изменения поля воспользуемся функцией sqlite_query() и передадим ей запрос на обновление (UPDATE).
<?php
  
// Создадим новую базу данных
  
$db sqlite_open("my_database.db");
  if (!
$db) exit("Невозможно создать базу данных!");
  
// Создадим таблицу "table1" в базе
  
$query_table sqlite_query($db"CREATE TABLE table1
                              (id INTEGER PRIMARY KEY,
                               /* id автоматически станет автоинкрементным */
                               field1 TEXT,
                               field2 TEXT);
                              "
);
  if (!
$query_table) exit("Невозможно создать таблицу в базе данных!");
  
// Запишем что-нибудь в таблицу
  
sqlite_query($db"INSERT INTO table1(field1, field2) VALUES ('PHP5+', 'Apache');");
  
sqlite_query($db"INSERT INTO table1(field1, field2) VALUES ('SQLite – ', 'классная вещь');");
  
sqlite_query($db"INSERT INTO table1(field1, field2) VALUES ('Посетите ', 'sqlite.org');");
  
// Изменим поле с id=1
  
sqlite_query($db"UPDATE table1 SET field2='Apache+Linux' WHERE id=1;");
  
// Сделаем выборку данных
  
$query sqlite_query($db"SELECT * FROM table1;");
  
// В цикле выведем все полученные данные
  
while ($array sqlite_fetch_array($query))
{
    echo(
$array['field1'].$array['field2']." (id записи:".$array['id'].")<br />");
  } 
?>
В результате получим:
PHP5+Apache+Linux (id записи:1)
SQLite – классная вещь (id записи:2)
посетите sqlite.org (id записи:3)
Удаление записи из таблицы: Чтобы удалить запись из таблицы, нужно передать функции sqlite_query() запрос на удаление (DELETE).
<?php
  
// Создадим новую базу данных
  
$db sqlite_open("my_database.db");
  if (!
$db) exit("Невозможно создать базу данных!");
  
// Создадим таблицу "table1" в базе
  
$query_table sqlite_query($db"CREATE TABLE table1
                              (id INTEGER PRIMARY KEY,
                               /* id автоматически станет автоинкрементным */
                               field1 TEXT,
                               field2 TEXT);
                              "
);
  if (!
$query_table) exit("Невозможно создать таблицу в базе данных!");
  
// Запишем что-нибудь в таблицу
  
sqlite_query($db"INSERT INTO table1(field1, field2) VALUES ('PHP5+', 'Apache');");
  
sqlite_query($db"INSERT INTO table1(field1, field2) VALUES ('SQLite – ', 'классная вещь');");
  
sqlite_query($db"INSERT INTO table1(field1, field2) VALUES ('Посетите ', 'sqlite.org');");
  
// Удалим поле с id=2
  
sqlite_query($db"DELETE FROM table1 WHERE id=2;");
  
// Сделаем выборку данных
  
$query sqlite_query($db"SELECT * FROM table1;");
  
// В цикле выведем все полученные данные
  
while ($array sqlite_fetch_array($query))
  {
    echo(
$array['field1'].$array['field2']." (id записи:".$array['id'].")<br />");
  } 
?>
В результате получим:
PHP5+Apache (id записи:1)
посетите sqlite.org (id записи:3)
Закрытие базы данных: Для закрытия базы данных используется функция sqlite_close(). В качестве единственного параметра функция принимает идентификатор открытой базы данных.
void sqlite_close ( resource dbhandle )
Схема использования данной функции представлена ниже
<?php
  $db 
sqlite_open("my_database.db");
  
/*
  ... Здесь происходит работа с БД ...
  */
  
sqlite_close($db); ?>

Замечание

Закрывать базу данных данной функцией – необязательно. Все открытые базы данных автоматически закроются при завершении работы скрипта.

Ссылки