3 ноября 2024, воскресенье  

PHPworld.ru - все о программировании на PHP, основы языка PHP, особенности PHP5
PHPworld.ru php php 5 SQLite Статьи Книги Форум PHP Гостевая книга Ссылки по PHP

SQLite


 

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

Рассмотрим на примере создание базы данных и таблицы SQLite в PHP 5:

<?php
      //  Создание базы/таблицы данных
     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() информационного сообщения об ошибке.

Обсудить на форуме

Дата публикации: 06.10.04
Последнее обновление: -
Просмотров: 26592

Copyright © PHP World - Леонид Лукин, 2004-2008.

Главная PHP World | PHP | PHP 5 | SQLite | Статьи по PHP | Книги по PHP | Ссылки по PHP | CV