Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:

5557

.pdf
Скачиваний:
4
Добавлен:
05.02.2023
Размер:
1.24 Mб
Скачать

30

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

В результате выполнения запроса на удаление будут удалены записи из подчиненных таблиц, для которых установлено «Каскадное удаление связанных записей».

Создание SQL-запросов

Для описания команд, используемых в SQL-запросах будем использовать следующий синтаксис написания SQL-предложений:

в описании команд слова, написанные прописными латинскими буквами, являются зарезервированными словами SQL;

фрагменты SQL-предложений, заключенные в фигурные скобки и разделенные символом « », являются альтернативными. При формировании соответствующей команды для конкретного случая необходимо выбрать одну из них;

фрагмент описываемого SQL-предложения, заключенный в квадратные скобки [ ], имеет необязательный характер и может не использоваться;

многоточие перед закрывающейся скобкой, говорит о том, что фрагмент, указанный в этих скобках, может быть повторен.

На рисунке 10 схематично представлен SQL-запрос на выборку данных из таблицы «Студент»

Рис. 10. Схематичное представление SQL-запроса

Для создания нового SQL-запроса в окне базы данных нажмите кнопку Создание запроса в режиме конструктора и, не выбирая табли-

цы, для запроса нажмите кнопку Вид на панели инструментов.

Для запуска запроса нажмите кнопку Запуск на панели инструментов.

31

Создание новой таблицы

Инструкция CREATE TABLE создает новую таблицу и используется для описания ее полей и индексов. Если для поля добавлено ограничение NOT NULL, то при добавлении новых записей это поле не должно содержать не существующих (NULL) данных. Синтаксис:

CREATE TABLE таблица (поле_1 тип [(размер)]

[NOT NULL] [индекс_1] [, поле_2 тип [(размер)]

[NOT NULL] [индекс_2] [, ...]] [, CONSTRAINT составной Индекс

[, ...]]),

где таблица – имя создаваемой таблицы; поле_1, поле_2 – имена одного или нескольких полей, создавае-

мых в новой таблице. Таблица должна содержать хотя бы одно поле; тип – тип данных поля в новой таблице; размер – размер поля в символах (только для текстовых и двоич-

ных полей);

индекс_1, индекс_2 – предложение CONSTRAINT, предназначенное для создания простого индекса;

составной Индекс – предложение CONSTRAINT, предназначенное для создания составного индекса.

В следующем примере представлено создание новой таблицы «Студент»:

CREATE TABLE Студент (Код_студента AUTOINCREMENT PRIMARY KEY, Номер_зачетной_книжки INTEGER , ФИО_студента

TEXT(50), Место_рождения TEXT (50));

В результате выполнения этого запроса в БД СУБД MS Access будет создана таблица «Студент» представленная в схеме БД следующим образом (рис. 11).

Рис. 11. Таблица «Студент» в схеме данных Предложение CONSTRAINT используется в инструкциях

ALTER TABLE и CREATE TABLE для создания или удаления индексов (индексы – это специальные объекты в БД, создаваемые с целью повышения быстродействия выполнения запросов, оптимизации хранения и доступа к данным, об индексах будет рассказано в следующем разделе учебного пособия). Существуют два типа предложений

32

CONSTRAINT: для создания простого индекса – по одному полю и для создания составного индекса – по нескольким полям Синтаксис:

простой индекс:

CONSTRAINT имя {PRIMARY KEY|UNIQUE | NOT NULL] [ON UPDATE {CASCADE | SET NULL}]

[ON DELETE {CASCADE | SET NULL}]}

составной индекс:

CONSTRAINT имя

{PRIMARY KEY (ключевое_1[, ключевое_2 [, ...]]) |

UNIQUE (уникальное_1[, уникальное_2 [, ...]]) | NOT NULL (непустое_1[, непустое_2 [, ...]]) | FOREIGN KEY (ссылка_1[, ссылка_2 [, ...]])

REFERENCES внешняя Таблица [(внешнее Поле_1 [, внешнее Поле_2 [, ...]])]

[ON UPDATE {CASCADE | SET NULL}] [ON DELETE {CASCADE | SET NULL}]} ,

где имя — имя индекса, который следует создать; ключевое_1, ключевое_2 – имена одного или нескольких полей,

которые следует назначить ключевыми; уникальное_1, уникальное_2 – имена одного или нескольких по-

лей, которые следует включить в уникальный индекс; непустое_1, непустое_2 – имена одного или нескольких полей, в

которых запрещаются значения Null;

ссылка_1, ссылка_2 – имена одного или нескольких полей, включенных во внешний ключ, которые содержат ссылки на поля в другой таблице;

внешняя Таблица – имя внешней таблицы, которая содержит поля, указанные с помощью аргумента внешнееПоле;

внешнее Поле_1, внешнее Поле_2 – имена одного или нескольких полей во внешней Таблице, на которые ссылаются поля, указанные с помощью аргумента ссылка_1, ссылка_2. Это предложение можно опустить, если данное поле является ключом внешней Таблицы.

ON UPDATE, ON DELETE обеспечивают автоматическое указание каскадного обновления связанных полей и каскадного удаления связанных записей в схеме БД (CASCADE) или обнуление соответствующих значений полей, являющихся внешними ключами (SET NULL). Данные ключевые слова актуальны, если в СУБД MS Access включить поддержку ANSI SQL, в противном случае в результате выполнения запроса будет выдана ошибка синтаксиса.

Предложение CONSTRAINT позволяет создать для поля индекс одного из двух описанных ниже типов:

33

1)уникальный индекс, использующий для создания зарезервированное слово UNIQUE. Это означает, что в таблице не может быть двух записей, имеющих одно и то же значение в этом поле. Уникальный индекс создается для любого поля или любой группы полей. Если в таблице определен составной уникальный индекс, то комбинация значений включенных в него полей должна быть уникальной для каждой записи таблицы, хотя отдельные поля и могут иметь совпадающие значения;

2)ключ таблицы, состоящий из одного или нескольких полей, использующий зарезервированные слова PRIMARY KEY. Все значения ключа таблицы должны быть уникальными и не зна-

чениями Null. Кроме того, в таблице может быть только один ключ.

Для создания внешнего ключа можно использовать зарезервированную конструкцию FOREIGN KEY. Если ключ внешней таблицы состоит из нескольких полей, необходимо использовать предложение CONSTRAINT. При этом следует перечислить все поля, содержащие ссылки на поля во внешней таблице, а также указать имя внешней таблицы и имена полей внешней таблицы, на которые ссылаются поля, перечисленные выше, причем в том же порядке. Однако, если последние поля являются ключом внешней таблицы, то указывать их необязательно, поскольку ядро базы данных считает, что в качестве этих полей следует использовать поля, составляющие ключ внешней таблицы.

В следующем примере создается таблица «Задолженность_за_обучение» с внешним ключом «Код_студента», связанным с полем «Код_студента», в таблице «Студент»:

CREATE TABLE Задолженность_за_обучение

(Код_задолженности AUTOINCREMENT PRIMARY KEY,

Код_студента INTEGER, Сумма_задолженности MONEY, CONSTRAINT f1_i FOREIGN KEY (Код_студента) REFERENCES Студент (Код_студента)

ON UPDATE CASCADE ON DELETE CASCADE );

Внешний вид схемы БД, состоящей из таблиц «Студент» и «Задолженность_за_обучение», представлен на рисунке 12. Здесь необходимо отметить, что дополнительные ключевые слова ON UPDATE CASCADE ON DELETE CASCADE позволили обеспечить автоматическое указание каскадного обновления связанных полей и каскадного удаления связанных записей в схеме БД.

34

Рис. 12. Схема данных после создания таблицы «Задолженность_за_обучение»

Создание индекса с помощью инструкции CREATE INDEX

CREATE INDEX создает новый индекс для существующей таблицы. Синтаксис команды:

CREATE [UNIQUE] INDEX индекс

ON таблица (поле [ASC|DESC][, поле [ASC|DESC], ...]) [WITH { PRIMARY | DISALLOW NULL | IGNORE NULL }]

где индекс – имя создаваемого индекса; таблица – имя существующей таблицы, для которой создается

индекс; поле – имена одного или нескольких полей, включаемых в ин-

декс. Для создания простого индекса, состоящего из одного поля, вводится имя поля в круглых скобках сразу после имени таблицы. Для создания составного индекса, состоящего из нескольких полей, перечисляются имена всех этих полей. Для расположения элементов индекса в убывающем порядке используется зарезервированное слово DESC; в противном случае будет принят порядок по возрастанию.

Чтобы запретить совпадение значений индексированных полей в разных записях, используется зарезервированное слово UNIQUE. Необязательное предложение WITH позволяет задать условия на значения. Например:

35

с помощью параметра DISALLOW NULL можно запретить значения Null в индексированных полях новых записей;

параметр IGNORE NULL позволяет запретить включение в индекс записей, имеющих значения Null в индексированных полях;

зарезервированное слово PRIMARY позволяет назначить индексированные поля ключом. Такой индекс по умолчанию является уникальным, следовательно, зарезервированное слово UNIQUE можно опустить.

В следующем примере создается уникальный индекс, не допускающий ввод повторяющихся значений в поле «Номер зачетной книжки» в таблице «Студент»:

CREATE UNIQUE INDEX New_index ON

Студент (Номер_зачетной_книжки) WITH IGNORE NULL Ключевые слова IGNORE NULL позволяют добавлять в таблицу

записи по студентам без обязательного ввода номера зачетной книжки (рис.13). Нажатие пиктограммы «Индексы» в конструкторе таблиц открывает одноименное окно с перечнем индексов для данной таблице, где отображается созданный в результате выполнения запроса уникальный индекс New_index.

Рис. 13 Результат создания уникального индекса

36

Создание запроса на удаление таблицы/индекса

Инструкция DROP удаляет существующую таблицу из базы данных или удаляет существующий индекс из таблицы. Синтаксис:

DROP {TABLE таблица | INDEX индекс ON таблица}

где таблица – имя таблицы, которую следует удалить или из которой следует удалить индекс;

индекс – имя индекса, удаляемого из таблицы.

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

В следующем примере удалим созданный в предыдущем примере индекс «New_index»:

DROP INDEX New_index ON Студент;

Создание запроса на добавление записей

Инструкция INSERT INTO добавляет запись или несколько записей в заданную таблицу.

Синтаксис команды:

а) запрос на добавление нескольких записей: INSERT INTO назначение [(поле_1[, поле_2[, ...]])] SELECT [источник.]поле_1[, поле_2[, ...]

FROM выражение

б) запрос на добавление одной записи:

INSERT INTO назначение [(поле_1[, поле_2[, ...]])] VALUES (значение_1[, значение_2[, ...])

где назначение — имя таблицы или запроса, в который добавляются записи;

источник – имя таблицы или запроса, откуда копируются записи; поле_1, поле_2 – имена полей для добавления данных, если они следуют за аргументом «Назначение»; имена полей, из которых берут-

ся данные, если они следуют за аргументом источник; выражение – имена таблицы или таблиц, откуда вставляются

данные. Это выражение может быть именем отдельной таблицы или результатом операции INNER JOIN, LEFT JOIN или RIGHT JOIN, а

также сохраненным запросом; значение_1, значение_2 – значения, добавляемые в указанные по-

ля новой записи. Каждое значение будет вставлено в поле, занимающее то же положение в списке: значение_1 вставляется в поле_1 в новой записи, значение_2 – в поле_2 и т.д. Каждое значение текстового поля следует заключать в кавычки (' '), для разделения значений используются запятые.

37

Инструкцию INSERT INTO можно использовать для добавления одной записи в таблицу с помощью запроса на добавление одной записи, описанного выше. В этом случае инструкция должна содержать имя и значение каждого поля записи. Нужно определить все поля записи, в которые будет помещено значение, и значения для этих полей. Если поля не определены, в недостающие столбцы будет вставлено значение по умолчанию или значение Null. Записи добавляются в конец таблицы.

Инструкцию INSERT INTO можно также использовать для добавления набора записей из другой таблицы или запроса с помощью предложения SELECT ... FROM, как показано выше в запросе на добавление нескольких записей. В этом случае предложение SELECT определяет поля, добавляемые в указанную таблицу Назначение. Инструкция INSERT INTO является необязательной, однако, если она присутствует, то должна находиться перед инструкцией SELECT.

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

Вместо добавления существующих записей из другой таблицы, можно указать значения полей одной новой записи с помощью предложения VALUES. Если список полей опущен, предложение VALUES должно содержать значение для каждого поля таблицы; в противном случае инструкция INSERT не будет выполнена. Можно использовать дополнительную инструкцию INSERT INTO с предложением VALUES для каждой добавляемой новой записи.

В следующем примере добавим новую запись в таблицу «Студент»:

INSERT INTO Студент (Номер_зачетной_книжки, ФИО_студента, Место_рождения, Дата_рождения )

VALUES (201454321, 'Иванов Иван Петрович', 'г. Томск',

'12.02.1996');

Заметим, что поскольку поле «Код_студента» имеет тип данных «Счетчик» и формируется автоматически, то в перечне новых значений для полей мы его опускаем. На рисунке 14 представлена таблица «Студент» с новой записью.

Рис. 14 Результат добавления записи в таблицу «Студент» Аналогично можно добавить данные в таблицу «Задолжен-

ность_за обучение».

38

Создание запроса на обновление данных

Инструкция UPDATE создает запрос на обновление, который изменяет значения полей указанной таблицы на основе заданного условия отбора.

Синтаксис команды: UPDATE таблица SET новое Значение

WHERE условие Отбора;

где таблица — имя таблицы, данные в которой следует изменить; новое Значение — выражение, определяющее значение, которое

должно быть вставлено в указанное поле обновленных записей; условие Отбора — выражение, отбирающее записи, которые

должны быть изменены.

При выполнении этой инструкции будут изменены только записи, удовлетворяющие указанному условию. Инструкцию UPDATE особенно удобно использовать для изменения сразу нескольких записей или в том случае, если записи, подлежащие изменению, находятся в разных таблицах. Одновременно можно изменить значения нескольких полей. Следующая инструкция SQL увеличивает сумму задолженности всех студентов, по которым есть сведения в таблице «Задолженность за обучение» на 10%:

UPDATE Задолженность_за_обучение

SET Сумма_задолженности = Сумма_задолженности * 1.1;

Создание запроса на выборку записей

Инструкция SELECT. При выполнении инструкции SELECT СУБД находит указанную таблицу или таблицы, извлекает заданные столбцы, выделяет строки, соответствующие условию отбора, и сортирует или группирует результирующие строки в указанном порядке в виде набора записей.

Синтаксис команды:

SELECT [предикат] { * | таблица.* | [таблица.]поле_1

[AS псевдоним_2] [, [таблица.]поле_2[AS псевдоним_2] [, ...]]} FROM выражение [, ...]

[WHERE... ] [GROUP BY... ] [HAVING... ] [ORDER BY... ]

где предикат – один из следующих предикатов отбора: ALL, DISTINCT, DISTINCTROW, TOP. Данные ключевые слова используются для ограничения числа возвращаемых записей. Если они отсутствуют, по умолчанию используется предикат ALL;

39

* указывает, что результирующий набор записей будет содержать все поля заданной таблицы или таблиц. Следующая инструкция отбирает все поля из таблицы «Студенты»: SELECT * FROM Студенты;

таблица – имя таблицы, из которой выбираются записи; поле_1, поле_2 – имена полей, из которых должны быть отобраны

данные; псевдоним_1, псевдоним_2 – ассоциации, которые станут заго-

ловками столбцов вместо исходных названий полей в таблице; выражение – имена одной или нескольких таблиц, которые со-

держат необходимые для отбора записи;

предложение GROUP BY в SQL-предложении объединяет записи с одинаковыми значениями в указанном списке полей в одну запись. Если инструкция SELECT содержит статистическую функцию SQL, например Sum или Count, то для каждой записи будет вычислено итоговое значение;

предложение HAVING определяет, какие сгруппированные записи, выданные в результате выполнения запроса, отображаются при использовании инструкции SELECT с предложением GROUP BY. После того как записи результирующего набора будут сгруппированы с помощью предложения GROUP BY, предложение HAVING отберет те из них, которые удовлетворяют условиям отбора, указанным в предложении HAVING;

предложение ORDER BY позволяет отсортировать записи, полученные в результате запроса, в порядке возрастания или убывания

на основе значений указанного поля или полей.

Следует отметить, что инструкции SELECT не изменяют данные в базе данных.

Для более наглядного представления результатов выполнения запросов на выборку добавим в нашу базу данных таблицы «Дисциплины» и «Успеваемость» и добавим поле «Номер_группы» в таблицу «Студенты» (рис. 15), а также заполним эти таблицы.

Рис. 15 Обновленная схема базы данных

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]