В отличие от реляционной алгебры, где были представлены только операции запросов к БД, SQL является полным языком, в нем присутствуют не только операции запросов, но и операторы, соответствующие DDL — Data Definition Language — языку описания данных. Кроме того, язык содержит операторы, предназначенные для управления (администрирования) БД. SQL содержит разделы, представленные в таблице 5.1:
Таблица 5.1. Операторы определения данных DDL
| Оператор | Смысл | Действие | ||
| CREATE TABLE | Создать таблицу | Создает новую таблицу в БД | ||
| DROP TABLE | Удалить таблицу | Удаляет таблицу из БД | ||
| ALTER TABLE | Изменить таблицу | Изменяет структуру существующей таблицы или ограничения целостности, задаваемые для данной таблицы | ||
| CREATE VIEW | Создать представление | Создает виртуальную таблицу, соответствующую некоторому SQL-запросу | ||
| ALTER VIEW | /Изменить представление | Изменяет ранее созданное представление | ||
| DROP VIEW | Удалить представление | Удаляет ранее созданное представление | ||
| CREATE INDEX | Создать индекс | Создает индекс для некоторой таблицы для обеспечения быстрого доступа по атрибутам, входящим в индекс | ||
| DROP INDEX | Удалить индекс | Удаляет ранее созданный индекс | ||
Таблица 5.2. Операторы манипулирования данными Data Manipulation Language (DMP)
| Оператор | Смысл | Действие | ||
| DELETE | Удалить строки | Удаляет одну или несколько строк, соответствующих условиям фильтрации, из базовой таблицы. Применение оператора согласуется с принципами поддержки целостности, поэтому этот оператор не всегда может быть выполнен корректно, даже если синтаксически он записан правильно | ||
| INSERT | Вставить строку | Вставляет одну строку в базовую таблицу. Допустимы модификации оператора, при которых сразу несколько строк могут быть перенесены из одной таблицы или запроса в базовую таблицу | ||
| UPDATE | Обновить строку | Обновляет значения одного или нескольких столбцов в одной или нескольких строках, соответствующих условиям фильтрации | ||
Таблица 5.3. Язык запросов Data Query Language (DQL)
| Оператор | Смысл | Действие | ||
| SELECT | Выбрать строки | Оператор, заменяющий все операторы реляционной алгебры и позволяющий сформировать результирующее отношение, соответствующее запросу | ||
Таблица 5.4. Средства управления транзакциями
| Оператор | Смысл | Действие | ||
| COMMIT | Завершить транзакцию | Завершить комплексную взаимосвязанную обработку информации, объединенную в транзакцию | ||
| ROLLBACK | Откатить транзакцию | Отменить изменения, проведенные в ходе выполнения транзакции | ||
| 'SAVEPOINT | Сохранить промежуточную точку выполнения транзакции | Сохранить промежуточное состояние БД, пометить его для того, чтобы можно было в дальнейшем к нему вернуться | ||
Таблица 5.5. Средства администрирования данных
| Оператор | Смысл | Действие | ||
| ALTER DATABASE | Изменить БД | Изменить набор основных объектов в базе данных, ограничений, касающихся всем базы данных | ||
| ALTER -DBAREA | Изменить область хранения БД | Изменить ранее созданную область храпения | ||
Таблица 5.5 (продолжение)
| Оператор | Смысл | Действие | ||
| ALTER PASSWORD | Изменить пароль | Изменить пароль для всей базы данных | ||
| CREATE DATABASE | Создать БД | Создать новую базу данных, определив основные параметры для нее | ||
| CREATE DBAREA | Создать область хранения | Создать новую область хранения и сделать ее доступной для размещения данных | ||
| DROP DATABASE | Удалить БД | Удалить существующую базу данных (только в том случае, когда вы имеете право выполнить это действие) | ||
| DROP DBAREA | Удалить область хранения БД | Удалить существующую область хранения (если в ней на настоящий момент не располагаются активные данные) | ||
| GRANT | Предоставить права | Предоставить нрава доступа на ряд действий над некоторым объектом БД | ||
| REVOKE | Лишить прав | Лишить прав доступа к некоторому объекту или некоторым действиям над объектом | ||
Таблица 5.6. Программный SQL
| Оператор | Смысл | Действие | ||
| DECLARE | Определяет курсор для запроса | Задает некоторое имя и определяет связанный с ним запрос к БД, который соответствует виртуальному набору данных | ||
| OPEN | Открыть курсор | Формирует виртуальный набор данных, соответствующий описанию указанного курсора и текущему состоянию БД | ||
| FETCH | Считать строку из множества строк, определенных курсором | Считывает очередную строку, заданную параметром команды из виртуального набора данных, соответствующего открытому курсору | ||
| CLOSE | Закрыть курсор | Прекращает доступ к виртуальному набору данных, соответствующему указанному курсору | ||
| PREPARE | Подготовить оператор SQL к динамическому выполнению | Сгенерировать план выполнения запроса, соответствующего заданному оператору SQL | ||
| Оператор | Смысл | Действие | ||
| EXECUTE | Выполнить оператор SQL, ранее подготовленный к динамическому выполнению | Выполняет ранее подготовленный план запроса | ||
В коммерческих СУБД набор основных операторов расширен. В большинство СУБД включены операторы определения и запуска хранимых процедур и операторы определения триггеров.






