logo search
Программирование в среде Delphy / Программирование в среде Delphi

29.1. Основные определения

База данных – это набор взаимосвязанных таблиц, которые могут храниться в отдельных файлах (Dbase, Paradox и т.д.) или в одном файле (Access).

Таблица – набор полей (столбцов), количество которых почти постоянно, и записей (строк), количество которых меняется в процессе работы.

Рассмотрим пример базы данных, содержащей две таблицы. Одна таблица будет представлять список сотрудников – TSPIS, а вторая – список должностей – TDOL:

Таблица TSPIS

ID

FIO

CODEDOL

STAG

DATEB

OKLAD

01

Иванов

2

10

11.02.1970

300000

02

Сидоренко

1

5

21.11.1981

200000

В этой таблице 6 полей: ID – номер сотрудника; FIO – фамилия, имя и отчество; CODEDOL – код должности; STAG – стаж работы; DATEB – дата рождения; OKLAD – оклад сотрудника.

Таблица TDOL

CODE

NAMEDOL

1

Инженер

2

Техник

….

…..

В таблице TDOL всего 2 поля: CODE – код должности, NAMEDOL – наименование должности. Эти две таблицы будут в дальнейшем связаны по полю CODEDOL таблицы TSPIS и полю CODE таблицы TDOL, это позволяет существенно экономить память, занимаемую таблицами, так как код должности занимает в основной таблице гораздо меньше места, чем наименование должности. Обычно эти связываемые таблицы называют справочниками.

Обычно первые поля таблиц определяют ключ записи или строки. Его значение должно быть уникально и не может повторяться. Строки в таблицах реляционных баз данных образуют множество, они не имеют последовательных номеров, а для их идентификации используется значение ключа.

Индексные поля определяют порядок сортировки строк таблицы. Индекс может залаваться одним полем, несколькими полями или выражением от значений полей. Индексы позволяют значительно ускорить поиск информации в таблице по значению индексного поля за счет предварительной сортировки записей и использования бинарного поиска. Например, если таблица содержит 1000 записей, то для поиска нужной строки в среднем надо произвести 500 сравнений. Бинарный поиск уменьшает число сравнений до 10, так как 1000 ~ 210. Индексы приводят к появлению дополнительных таблиц в базе данных.

Домен – это диапазон или набор значений какого–либо поля.

Сессия – представляет собой канал связи с базой данных. Приложение может иметь несколько сессий. Сессии являются владельцами курсоров и блокировок.

Курсор – специальный объект, в котором хранятся текущий набор строк таблицы и информация о закладках (BookMark). Все операции с таблицами осуществляются только через курсор. Он позволяет ускорить работу с таблицами, т.к. его буфер хранит не одну, а 100–1000 строк таблицы, что позволяет существенно реже обращаться к файлам таблиц. Курсор может находиться как на стороне сервера, так и на стороне клиента.

Клиент – приложение, которое задает вопросы.

Сервер – приложение, которое отвечает на вопросы.

Запрос – оператор на языке SQL (Structured Query Language).

Транзакция – система взаимосвязанных действий по изменению базы данных. Она должна быть выполнена до конца или отменена полностью, т.е. должна быть предусмотрена возможность отката назад. Транзакция требует наличия дополнительной памяти для хранения временных изменений в базе данных.

Хранимая процедура – набор SQL запросов, хранимых на сервере, который можно вызвать со стороны клиента по одному имени.