- Тема: Создание запросов с использованием «GROUP BY» и «HAVING»..
Язык SQL - СУБД System R - экспериментальная исследовательская система с языком SEQUEL (позже SQL ), созданная IBM:
- - Полный реляционный язык БД
- - Операторы манипулирования БД
- - Средства определения и манипулирования схемой БД
- - Определение ограничений целостности
- - Определение представлений
- - Определение индексов
- - Авторизация доступа к отношениям и их полям
- Точки сохранения транзакций и откаты
- Стандарты SQL1, SQL2, SQL3 (1992)
- Cодержит только набор стандартных операторов доступа к данным, хранящимся в базе данных. Операторы SQL встраиваются в базовый язык программирования
Достоинства: - Достоинства:
- Повсеместная распространенность
- Быстрое обучение в простых случаях
- Связывание с различными языками программирования
- Поддержка ODBC и JDBC
- Фактор времени: научились хорошо реализовывать.
- Недостатки:
- Несоответствие реляционной модели данных (наличие дубликатов, необязательность первичного ключа, возможность упорядочения результатов)
- Недостаточно продуманный механизм неопределенных значений
- Сложность формулировок и громоздкость.
- Литература
- Базы данных: модели реализация / Т. С. Карпова. - СПб.: Питер, 2001. - 304 с.: ил.
- Хомоненко А. Д., Цыганков В. М., Мальцев М. Г. Базы данных: Учебник для высших учебных заведений /Под. ред. проф. А. Д. Хомоненко. - СПб.: КОРОНА принт, 2000. - 416 с.
- Язык запросов ( Data Query Language ) в SQL состоит из единственного оператора SELECT Этот единственный оператор поиска реализует все операции реляционной алгебры. Синтаксис оператора SELECT имеет следующий вид:
- SELECT [ALL | DISTINCT] < список полей >|*)
- FROM < Слисок таблиц >
- [ WHERE < Предикат - условие выборки или соединения >]
- [ GROUP BY < Список полей результата >]
- [ HAVING < Предикат - условие для группы >]
- [ ORDER BY < Список полей , по которым упорядочить вывод >]
- Ключевое слово ALL означает, что в результирующий набор строк включаются все строки, удовлетворяющие условиям запроса. Значит, в результирующий набор могут попасть одинаковые строки. И это нарушение принципов теории отношений.
- DISTINCT означает, что в результирующий набор включаются только различные строки, то есть дубликаты строк результата не включаются в набор. Символ *. означает, что в результирующий набор включаются все столбцы из исходных таблиц запроса. В разделе FROM задается перечень исходных отношений (таблиц) запроса. В разделе WHERE задаются условия отбора строк результата или условия соединения кортежей исходных таблиц
Do'stlaringiz bilan baham: |