Работаем с SQLite
Создание базы данных и таблицы SQLite
Рассмотрим на примере создание базы данных и таблицы SQLite в PHP 5:
// Создание базы/таблицы данных
error_reporting(0); // Отключение вывода стандартных сообщений об ошибках
try {
if (!file_exists("sample.db")) {
// Базы нет, создаем ее
$db = sqlite_open("sample.db");
if (!$db) throw new Exception("невозможно создать базу!");
$sql = "CREATE TABLE test
(
id INTEGER PRIMARY KEY, -- автоинкремент
textfield TEXT, -- текстовое поле неограниченной длины
intfield INTEGER(2) -- числовое поле
)";
sqlite_query($db, $sql);
if (sqlite_last_error($db)) throw new Exception("невозможно создать таблицу в базе!");
echo "База и таблица созданы";
sqlite_close($db);
}
} catch (Exception $exception) {
echo "Произошла ошибка в строке", $exception->getLine()-1, ": ",
$exception->getMessage();
}
?>
Поскольку удобнее всего для обработки ошибок применять в PHP 5 новую конструкцию try/catch/throw, которая будет также выводить информацию о возникшей ошибке, то в самом начале PHP сценария будет уместно функцией error_reporting() отключить вывод стандартных сообщений об ошибках.
Далее идет блок try, в котором проверяется наличие файла базы данных. Если такового не существует – переходим к его созданию функцией sqlite_open(), которая не только открывает файлы баз данных, но и создает его в случае отсутствия, чем мы и воспользуемся в нашем сценарии. В случай невозможности создания файла через throw new Exception() генерируется исключение и управление передается в блок catch для вывода сообщения об ошибке и завершения сценария. Если же создание файла базы произошло успешно – формируется SQL-запрос на создание тестовой таблицы.
Каким же должен быть SQL-запрос для создания таблицы, учитывая бестиповый характер таблиц SQLite? Все очень и очень просто - при описании полей таблицы принимаются в расчет только имена полей. Указание типов полей и их максимальной длины является необязательным и SQLite’ом не учитывается! Исключение составляет только первичный ключ (PRIMARY KEY), объявленный как INTEGER – такое поле автоматически становится автоинкрементным.
Таким образом, аналогичную таблицу можно было бы создать и таким SQL-оператором:
CREATE TABLE test(id INTEGER PRIMARY KEY, textfield, intfield)
Выполнение запроса к базе производится функцией sqlite_query(), а проверка успешности выполнения запрос функцией sqlite_last_error().
Необязательно закрытие соединения с базой SQLite выполняется функцией sqlte_close().
В случае генерации любого исключения в блоке catch методом getLine() объекта $exception осуществляется вывод номера строки, где ошибка произошла, и методом getMessage() информационного сообщения об ошибке.
Сохранение данных в таблицу SQLite
Добавим в нашу тестовую таблицу SQLite некоторые значения.
// Ввод данных в базу/таблицу
error_reporting(0); // Отключение вывода стандартных сообщений об ошибках
try {
if (file_exists("sample.db")) {
// Открытие файла базы
$db = sqlite_open("sample.db");
if (!$db) throw new Exception("невозможно открыть базу!");
$sql = "INSERT INTO test(textfield, intfield) VALUES(''PHP version'', 5)";
sqlite_query($db, $sql);
if (sqlite_last_error($db)) throw new Exception("невозможно добавить данные в таблицу!");
echo "Данные в таблицу добавлены успешно";
sqlite_close($db);
}
} catch (Exception $exception) {
echo "Произошла ошибка в строке ", $exception->getLine()-1, ": ",
$exception->getMessage();
}
?>
По сравнению с предыдущим сценарием создания таблицы с точки зрения PHP в представленном коде нет ничего нового. Тем не менее, стоит обратить внимание на SQL-оператор INSERT добавления данных в таблицу. В его записи нет неожиданностей. Однако, учитывая бестиповый характер таблиц SQLite возможен и следующий вариант, который не будет являться ошибочным:
INSERT INTO test(textfield, intfield) VALUES(5,''PHP version'')
В этом примере числовое значение записывается в текстовое поле, а символьное значение в целочисленное! Поскольку при создании таблицы типы полей, указанные в операторе CREATE TABLE игнорируются, SQLite позволяет вставлять данные любого типа в любые поля! Единственно, когда типы в SQLite имеют значение – это процесс сортировки или выборки данных по условиям, при этом приведение типов SQLite выполняет автоматически.
Вывод данных из таблицы SQLite
Теперь посмотрим, каким образом PHP 5 может произвести вывод данных из созданной нами таблицы.
// Вывод данных из базы/таблицы
error_reporting(0); // Отключение вывода стандартных сообщений об ошибках
try {
if (file_exists("sample.db")) {
// Открытие файла базы
$db = sqlite_open("sample.db");
if (!$db) throw new Exception("невозможно открыть базу!");
$sql = "SELECT * FROM test";
$result = sqlite_query($db, $sql);
if (sqlite_last_error($db)) throw new Exception("невозможно выбрать данные из таблицы!");
while ($row = sqlite_fetch_object($result)) {
echo "Поле 1: " . $row->textfield . "\n";
echo "Поле 2: " . $row->intfield . "\n";
}
sqlite_close($db);
}
} catch (Exception $exception) {
echo "Произошла ошибка в строке ", $exception->getLine()-1, ": ",
$exception->getMessage();
}
?>
Выполняя запрос SELECT необходимо результат сохранять в переменную, которая будет иметь ресурсный тип ($result). Вывод данных из такой переменной возможен множеством способов, однако в любом случае потребуется перебор всех записей, как это делалось и при работе с MySQL.
В данном примере используется функция sqlite_fetch_object(), возвращающая данные одной записи в виде объекта. Получить же значение одного конкретного поля из такого объекта можно, обратившись к его свойству, имя которого совпадает с именем поля.
Как это принято в PHP, функция sqlite_fetch_object() возвратит FALSE, в случае прохода по всем записям вернувшихся значений, вот почему ее использование удачно сочетается с оператором цикла while.


Дайджест новых статей по интернет-маркетингу на ваш email
Новые статьи и публикации
- 2025-03-14 » SPF-запись
- 2025-03-07 » SEO на маркетплейсах: как оптимизировать карточку товара для поисковой выдачи
- 2025-02-18 » Топ-10 бесплатных нейросетей для генерации изображений: лучшие ии генераторы 2024 года
- 2025-02-11 » Критическая уязвимость в 1С-Битрикс
- 2025-02-11 » Google Search Console: руководство для начинающих вебмастеров
- 2025-02-11 » Методы измерения результативности рекламных кампаний: плюсы и минусы
- 2025-02-11 » Тренды SEO в 2025 году
- 2025-02-10 » Свой Google в локалке. Ищем иголку в стоге сена
- 2025-01-29 » SEO — это комплексная работа. Шесть главных факторов ранжирования сайтов
- 2025-01-29 » Гайд для главной страницы e-commerce сайта: как оформить, чтобы повысить конверсию
- 2025-01-20 » Krea AI выпустила бесплатную функцию преобразования изображений в 3D-объекты — их можно вращать и вписывать в фотографии
- 2025-01-15 » Топ-6 лучших российских нейросетей, в которых можно генерировать тексты и изображения бесплатно и без VPN
- 2025-01-14 » 15 бесплатных способов узнать, чем интересуется ваша аудитория
- 2025-01-11 » Бездепозитные бонусы в казино за регистрацию с выводом: особенности и возможности получения
- 2025-01-09 » Новая модель LAM способна выполнять задачи в Word
- 2024-12-26 » Универсальный промпт для нейросети: как выжать максимум из ChatGPT, YandexGPT, Gemini, Claude в 2025
- 2024-11-26 » Капитан грузового судна, или Как начать использовать Docker в своих проектах
- 2024-11-26 » Обеспечение безопасности ваших веб-приложений с помощью PHP OOP и PDO
- 2024-11-22 » Ошибки в Яндекс Вебмастере: как найти и исправить
- 2024-11-22 » Ошибки в Яндекс Вебмастере: как найти и исправить
- 2024-11-15 » Перенос сайта на WordPress с одного домена на другой
- 2024-11-08 » OSPanel 6: быстрый старт
- 2024-11-08 » Как установить PhpMyAdmin в Open Server Panel
- 2024-09-30 » Как быстро запустить Laravel на Windows
- 2024-09-25 » Next.js
- 2024-09-05 » OpenAI рассказал, как запретить ChatGPT использовать содержимое сайта для обучения
- 2024-08-28 » Чек-лист: как увеличить конверсию интернет-магазина на примере спортпита
- 2024-08-01 » WebSocket
- 2024-07-26 » Интеграция с Яндекс Еда
- 2024-07-26 » Интеграция с Эквайринг
"Самый чепуховый и бесперспективный проект, но уже запущенный и работающий в Сети, принесет гораздо больше результатов и прибыли, чем самый совершенный проект, который из-за своего постоянного предстартового совершенствования никогда не будет запущен." |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.
Или напишите нам в WhatsApp
Или напишите нам в WhatsApp