Автор работы: Пользователь скрыл имя, 31 Октября 2011 в 19:51, реферат
SQL ( Structured Query Language - «язык структурированных запросов») - универсальный компьютерный язык, применяемый для создания, модификации и управления данными в реляционных базах данных. Реляционная база данных - база данных, основанная на реляционной модели данных. Реляционная модель данных (РМД) - логическая модель данных, прикладная теория построения баз данных, которая является приложением к задачам обработки данных таких разделов математики как теории множеств и логика первого порядка.
Каждая таблица описывается в виде перечисления своих полей (столбцов таблицы) с указанием:
Запросы первого типа, в свою очередь, делятся на запросы, предназначенные для создания в базе данных новых таблиц, и на запросы, предназначенные для изменения уже существующих таблиц. Запросы второго типа оперируют со строками, и их можно разделить на запросы следующего вида:
Самый главный вид запроса - это запрос, возвращающий (пользователю) некоторый набор строк, с которым можно осуществить одну из трёх операций:
Таким образом, использование SQL сводится, по сути, к формированию всевозможных выборок строк и совершению операций над всеми записями, входящими в набор.
Язык SQL представляет собой совокупность
Согласно общепринятому стилю программирования, операторы (и другие зарезервированные слова) в SQL всегда следует писать прописными буквами.
Операторы SQL делятся на:
Несмотря
на наличие диалектов и различий в синтаксисе,
в большинстве своём тексты SQL-запросов,
содержащие DDL и DML, могут быть достаточно
легко перенесены из одной СУБД в другую.
Существуют системы, разработчики которых
изначально ориентировались на применение
по меньшей мере нескольких СУБД (например:
система электронного документооборота Documentum
может работать как с Oracle,
так и с Microsoft
SQL Server и IBM DB2).
Естественно, что при применении некоторых
специфичных для реализации возможностей
такой переносимости добиться уже очень
трудно.
Наличие стандартов.
Наличие стандартов и набора тестов для выявления совместимости и соответствия конкретной реализации SQL общепринятому стандарту только способствует «стабилизации» языка. Правда, стоит обратить внимание, что сам по себе стандарт местами чересчур формализован и раздут в размерах (например, Core-часть стандарта SQL:2003 представляет собой более 1300 страниц текста).
С помощью SQL программист описывает только то, какие данные нужно извлечь или модифицировать. То, каким образом это сделать, решает СУБД непосредственно при обработке SQL-запроса. Однако не стоит думать, что это полностью универсальный принцип - программист описывает набор данных для выборки или модификации, однако ему при этом полезно представлять, как СУБД будет разбирать текст его запроса. Чем сложнее сконструирован запрос, тем больше он допускает вариантов написания, различных по скорости выполнения, но одинаковых по итоговому набору данных.
Создатели реляционной модели данных Эдгар Кодд, Кристофер Дейт и их сторонники указывают на то, что SQL не является истинно реляционным языком. В частности, они указывают на следующие проблемы SQL:
В опубликованном Кристофером Дейтом и Хью Дарвеном Третьем Манифесте они излагают принципы СУБД следующего поколения и предлагают язык Tutorial D, который является подлинно реляционным.
Хотя SQL и задумывался как средство работы конечного пользователя, в конце концов он стал настолько сложным, что превратился в инструмент программиста.
Несмотря на наличие международного стандарта ANSI SQL-92, многие компании, занимающиеся разработкой СУБД (например, Oracle, Sybase, Microsoft, MySQL AB), вносят изменения в язык SQL, применяемый в разрабатываемой СУБД, тем самым отступая от стандарта. Таким образом, появляются специфичные для каждой конкретной СУБД диалекты языка SQL.
Ранее
диалекты SQL большинства СУБД не предлагали
способа манипуляции
Типы данных.
В
SQL используются следующие основные
типы данных, форматы которых могут
несколько различаться для
INTEGER - целое число (обычно до 10 значащих цифр и знак);
SMALLINT - "короткое целое" (обычно до 5 значащих цифр и знак);
DECIMAL(p,q) - десятичное число, имеющее p цифр (0 < p < 16) и знак; с помощью q задается число цифр справа от десятичной точки (q < p, если q = 0, оно может быть опущено);
FLOAT - вещественное число с 15 значащими цифрами и целочисленным порядком, определяемым типом СУБД;
CHAR(n) - символьная строка фиксированной длины из n символов (0 < n < 256);
VARCHAR(n) - символьная строка переменной длины, не превышающей n символов (n > 0 и разное в разных СУБД, но не меньше 4096);
DATE - дата в формате, определяемом специальной командой (по умолчанию mm/dd/yy); поля даты могут содержать только реальные даты, начинающиеся за несколько тысячелетий до н.э. и ограниченные пятым-десятым тысячелетием н.э.;
TIME - время в формате, определяемом специальной командой, (по умолчанию hh.mm.ss);
DATETIME - комбинация даты и времени;
MONEY
- деньги в формате, определяющем символ
денежной единицы ($, руб, ...) и его расположение
(суффикс или префикс), точность дробной
части и условие для показа денежного
значения.
В
некоторых СУБД еще существует тип
данных LOGICAL, DOUBLE и ряд других. СУБД INGRES
предоставляет пользователю возможность
самостоятельного определения новых типов
данных, например, плоскостные или пространственные
координаты, единицы различных метрик,
пяти- или шестидневные недели (рабочая
неделя, где сразу после пятницы или субботы
следует понедельник), дроби, графика,
большие целые числа (что стало очень актуальным
для российских банков) и т.п.
SQL-функции.
В
SQL существует ряд специальных стандартных
функций (SQL-функций). Кроме специального
случая COUNT(*) каждая из этих функций
оперирует совокупностью
COUNT - число значений в столбце,
SUM - сумма значений в столбце,
AVG - среднее значение в столбце,
MAX - самое большое значение в столбце,
MIN - самое малое значение в столбце.
Для функций SUM и AVG рассматриваемый столбец должен содержать числовые значения.
Следует
отметить, что здесь столбец - это
столбец виртуальной таблицы, в
которой могут содержаться
Аргументу
всех функций, кроме COUNT(*), может предшествовать
ключевое слово DISTINCT (различный), указывающее,
что избыточные дублирующие значения
должны быть исключены перед тем,
как будет применяться функция.
Специальная же функция COUNT(*) служит
для подсчета всех без исключения
строк в таблице (включая дубликаты).
Возможности SQL.
В
начале 70-х годов SQL являлся лишь
языком запросов (ЯЗ). Он, по сути, содержал
только предложение SELECT, которое позволяло
формулировать запросы для
SQL существует в двух формах. В интерактивном SQL пользователь непосредственно вводит команды и получает результат. Команды встроенного SQL включаются в тексты программ на других языках. В этом случае обращение к базе данных, а также обработка результатов производится этими программами.
SQL-технологии.
Язык.
Общение с сервером СУБД происходит на языке структурированных запросов SQL (Structured Query Language). Базовый набор языка стандартизован ANSI. Действующая редакция ANSI SQL92. Это непроцедурный язык. Он предназначен именно для построения запросов и манипуляции данными и структурами данных. У него нет ни переменных, ни меток, ни циклов, ни всего прочего, с чем привык работать нормальный программист. Надо четко представлять себе, что SQL оговаривает способ передачи данных в клиентскую программу, но никак не оговаривает то, как эти данные должны в клиентской программе обрабатываться и представляться пользователю.