Шрифт:
Еще раз стоит повторить, что выбор учебной базы данных не влияет на синтаксис использованных средств, так как модуль sqlite, который будет использоваться, поддерживает DB–API 2.0, а значит, переход на любую другую СУБД потребует минимальных изменений в вызове функции connect и, возможно, использования более удачных типов данных, свойственных целевой СУБД.
Схематично работа с базой данных может выглядеть примерно так:
Подключение к базе данных (вызов connect с получением объекта–соединения).
Создание одного или нескольких курсоров (вызов метода объекта–соединения cursor с получением объекта–курсора).
Исполнение команды или запроса (вызов метода execute или его вариантов).
Получение результатов запроса (вызов метода fetchone или его вариантов).
Завершение транзакции или ее откат (вызов метода объекта–соединения commit или rollback).
Когда все необходимые транзакции произведены, подключение закрывается вызовом метода close объекта–соединения.
Знакомство с СУБД
Допустим, программное обеспечение установлено правильно, и можно работать с модулем sqlite. Стоит посмотреть, чему будут равны константы:
Листинг
>>> import sqlite
>>> sqlite.apilevel
'2.0'
>>> sqlite.paramstyle
'pyformat'
>>> sqlite.threadsafety
1
Отсюда следует, что sqlite поддерживает DB–API 2.0, подстановка параметров выполняется в стиле строки форматирования языка Python, а соединения нельзя совместно использовать из различных потоков управления (без блокировок).
Создание базы данных
Для создания базы данных нужно установить, какие таблицы (и другие объекты, например индексы) в ней будут храниться, а также определить структуры таблиц (имена и типы полей).
Задача — создание базы данных, в которой будет храниться телепрограмма. В этой базе будет таблица со следующими полями:
tvdate,
tvweekday,
tvchannel,
tvtime1,
tvtime2,
prname,
prgenre.
Здесь tvdate — дата, tvchannel — канал, tvtime1 и tvtime2 — время начала и конца передачи, prname — название, prgenre — жанр. Конечно, в этой таблице есть функциональная зависимость (tvweekday вычисляется на основе tvdate и tvtime1), но из практических соображений БД к нормальным формам приводиться не будет. Кроме того, таблица будет создана с названиями дней недели (устанавливает соответствие между номером дня и днем недели):
weekday,
wdname.
Следующий сценарий создаст таблицу в базе данных (в случае с SQLite заботиться о создании базы данных не нужно: файл создастся автоматически. Для других баз данных необходимо перед этим создать базу данных, например, SQL–инструкцией CREATE DATABASE):
Листинг
import sqlite as db
c = db.connect(database=«tvprogram»)
cu = c.cursor
try:
cu.execute("""
CREATE TABLE tv (
tvdate DATE,
tvweekday INTEGER,
tvchannel VARCHAR(30),
tvtime1 TIME,
tvtime2 TIME,
prname VARCHAR(150),
prgenre VARCHAR(40)
);
«"")
except db.DatabaseError, x:
print «Ошибка: ", x
c.commit
try:
cu.execute("""
CREATE TABLE wd (
weekday INTEGER,
wdname VARCHAR(11)
);
«"")
except db.DatabaseError, x:
print «Ошибка: ", x
c.commit
c.close
Здесь просто исполняются SQL–инструкции, и обрабатывается ошибка базы данных, если таковая случится (например, при попытке создать таблицу с уже существующим именем). Для того чтобы таблицы создавались независимо, используется commit.
Кстати, удалить таблицы из базы данных можно следующим образом:
Листинг
import sqlite as db
c = db.connect(database=«tvprogram»)
cu = c.cursor
try:
cu.execute(""«DROP TABLE tv;""")
except db.DatabaseError, x:
print «Ошибка: ", x
c.commit
try:
cu.execute(""«DROP TABLE wd;""")
except db.DatabaseError, x:
print «Ошибка: ", x
c.commit
c.close
Наполнение базы данных
Теперь можно наполнить таблицы значениями. Следует начать с расшифровки числовых значений для дней недели:
Листинг
weekdays = [«Воскресенье», «Понедельник», «Вторник», «Среда»,
«Четверг», «Пятница», «Суббота», «Воскресенье»]
import sqlite as db
c = db.connect(database=«tvprogram»)
cu = c.cursor
cu.execute(""«DELETE FROM wd;""")
cu.executemany(""«INSERT INTO wd VALUES (%s, %s);""",
enumerate(weekdays))