Структура языка SQL. 8

Основные данные о работе

Версия шаблона

2.1

Филиал

 

Вид работы

Курсовая работа

Название дисциплины

Базы данных

Тема

Структура языка SQL

Фамилия студента

 

Имя студента

 

Отчество студента

 

№ контракта

 

 

Содержание

Введение.............................................................................................................

3

1 Введение в SQL...............................................................................................

5

1.1 Таблицы SQL................................................................................................

6

1. 2 Структура языка SQL.................................................................................

7

1. 3 Структура запросов SQL............................................................................

8

1.4 Операторы модификации данных..............................................................

17

1.5 Транзакции в SQL.......................................................................................

24

2 Защита данных................................................................................................

26

3 Обработка ошибок..........................................................................................

29

Заключение........................................................................................................

31

Глоссарий...........................................................................................................

33

Список использованных источников...............................................................

35

Приложение.......................................................................................................

36


Введение

В настоящее время объемы информации все время возрастают. Наиболее удобным способом хранения информации, на основе опыта нескольких десятилетий, был признан способ хранения информации в виде баз данных.


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

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

Язык для взаимодействия с БД SQL появился в середине 70-х  и был разработан в рамках проекта  экспериментальной реляционной  СУБД System R. Исходное название языка SEQUEL (Structered English Query Language) только частично отражает суть этого языка. Конечно, язык был ориентирован главным образом на удобную и понятную пользователям формулировку запросов к реляционной БД, но на самом деле уже являлся полным языком БД, содержащим помимо операторов формулирования запросов и манипулирования БД средства определения и манипулирования схемой БД. В языке отсутствовали средства синхронизации доступа к объектам БД со стороны параллельно выполняемых транзакций: с самого начала предполагалось, что необходимую синхронизацию неявно выполняет система управления базами данных СУБД.

После появления на рынке  двух пионерских СУБД – SQL/DS (1981 год) и DB2 (1983 год) – он приобрел статус стандарта  де-факто для профессиональных реляционных  СУБД. В 1987 году SQL стал официальным  международным стандартом языка баз данных, а в 1992 году вышла вторая версия этого стандарта.

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

При создании языка запросов нового поколения разработчики старались  сделать его простым и легким в освоении инструментом для обращения  к БД. В итоге SQL стал слабо структурированным языком, особенно по сравнению с такими языками, как С или Pascal, и в то же время достаточно мощным и относительно легким для изучения.

Одним из наиболее важных шагов на пути к признанию SQL на рынке стало появление стандартов на этот язык. Обычно при упоминании стандарта SQL имеют в виду официальный стандарт, утвержденный Американским институтом национальных стандартов (American National Standards Institute — ANSI) и Международной организацией по стандартам (International Standards Organization— ISO). Однако существуют и другие важные стандарты SQL, включая SQL, реализованный в системе DB2 компании IBM, и стандарт X/OPEN для SQL в среде UNIX. Этот стандарт, незначительно пересмотренный в 1989 году, обычно называют стандартом «SQL-89», или «SQLI».

Пробелы в стандарте SQL-89 и различия между существующими диалектами SQL достаточно значительны, и при переводе приложения под другую СУБД его всегда приходится модифицировать. Эти отличия в большинстве своем устранены в стандарте SQL2.

 

 

 

 

 

 

 

 

 

 

 

 

 

Основная часть

1 глава основной части

1 Введение  в SQL

 

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

На рисунке в приложении А изображена схема работы SQL.

Согласно этой схеме, в вычислительной системе имеется база данных, в которой хранится важная информация. Если пользователю необходимо прочитать данные из базы данных, он запрашивает их у SQL с помощью СУБД. SQL обрабатывает запрос, находит требуемые данные и посылает их пользователю. Процесс запрашивания данных и получения результата называется запросом к базе данных: отсюда и название — структурированный язык запросов.

Однако это название не совсем соответствует действительности. Cегодня SQL представляет собой нечто гораздо большее, чем простой инструмент создания запросов, хотя именно для этого он и был первоначально предназначен. Несмотря на то, что чтение данных по-прежнему остается одной из наиболее важных функций SQL, сейчас этот язык используется для реализации всех функциональных возможностей, которые СУБД предоставляет пользователю, а именно:1

  1. Организация данных. SQL дает пользователю возможность изменять структуру представления данных, а также устанавливать отношения между элементами базы данных.
  2. Чтение данных. SQL дает пользователю или приложению возможность читать из базы данных содержащиеся в ней данные и пользоваться ими.
  3. Обработка данных. SQL дает пользователю или приложению возможность изменять базу данных, т.е. добавлять в нее новые данные, а также удалять или обновлять уже имеющиеся в ней данные.
  4. Управление доступом. С помощью SQL можно ограничить возможности пользователя по чтению и изменению данных и защитить их от несанкционированного доступа.
  5. Совместное использование данных. SQL координирует совместное использование данных пользователями, работающими параллельно, чтобы они не мешали друг другу.
  6. Целостность данных. SQL позволяет обеспечить целостность базы данных, защищая ее от разрушения из-за несогласованных изменений или отказа системы.

1.1 Таблицы SQL

В реляционной базе данных информация организована в виде таблиц, разделённых на строки и столбцы, на пересечении которых содержатся значения данных.

Основными объектами  реляционной базы данных являются:

(TABLE) Таблица  - Прямоугольная таблица, состоящая из СТРОК и СТОЛБЦОВ. Задать таблицу – значит указать, из каких столбцов она состоит.

(ROW) Строка - Запись, состоящая из полей – столбцов. В каждом поле содержится его значение, либо значение NULL – «пусто». Строк в таблице может быть сколько угодно. Физический порядок их расположения друг относительно друга неопределен.

(COLUMN) Столбец - Каждый столбец в таблице имеет собственные имя и тип.

 

1.2 Структура  языка SQL

 

Все операторы языка SQL можно разделить на несколько типов:

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

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

Операторы модификации данных - позволяют создавать/удалять базовые таблицы и изменять их структуру (добавлять столбцы, связи между таблицами).

Операторы защиты данных - позволяют авторизировать пользователей, давать им привилегии (разрешения на просмотр данных из одной или нескольких таблиц, изменение данных и т.д.).

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

Оператор ошибки - после выполнения последнего SQL запроса содержит код выполнения операции (код ошибки либо удачного выполнения).

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

Таким образом, пользователю необходимо сформировать текстовую строку, содержащую операторы SQL и с помощью функции используемого им языка программирования высокого уровня отправить этот запрос на SQL Server, хранящий базу данных. В результате от SQL Server придет ответ, содержащий запрошенные данные из одной или нескольких таблиц, удовлетворяющие условию запроса, отсортированные в нужном порядке, либо произведет запрашиваемые действия над данными.

 

1.3 Структура  запросов SQL

 

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

В синтаксических конструкциях для обращения к БД используются следующие обозначения:

1) звездочка (*) для  обозначения «все» – употребляется  в обычном для программирования смысле, т.е. «все случаи, удовлетворяющие определению»;

2) квадратные скобки ([]) – означают, что конструкции,  заключенные в эти скобки, являются  необязательными (т.е. могут быть  опущены);

3) фигурные скобки ({}) – означают, что конструкции, заключенные в эти скобки, должны рассматриваться как целые синтаксические единицы, т.е. они позволяют уточнить порядок разбора синтаксических конструкций, заменяя обычные скобки, используемые в синтаксисе SQL;

4) многоточие (…) –  указывает на то, что непосредственно предшествующая ему синтаксическая единица факультативно может повторяться один или более раз;

5) прямая черта (|) –  означает наличие выбора из  двух или более возможностей. Например, обозначение ASC|DESC указывает,  можно выбрать один из терминов ASC или DESC; когда же один из элементов выбора заключен в квадратные скобки, то это означает, что он выбирается по умолчанию (так, [ASC]|DESC означает, что отсутствие всей этой конструкции будет восприниматься как выбор ASC);

6) точка с запятой  (;) – завершающий элемент предложений SQL;

7) запятая (,) – используется  для разделения элементов списков; 

8) пробелы ( ) – могут  вводиться для повышения наглядности  между любыми синтаксическими  конструкциями предложений SQL;

9) жирные прописные  латинские буквы и символы – используются для написания конструкций языка SQL и должны (если это специально не оговорено) записываться в точности так, как показано-……..;

10) строчные буквы используются  для написания конструкций, которые  должны заменяться конкретными  значениями, выбранными пользователем, причем для определенности отдельные слова этих конструкций связываются между собой символом подчеркивания (_);

11) термины «таблица»  и «столбец» заменяют (с целью  сокращения текста синтаксических  конструкций) термины «имя_таблицы», «имя_столбца», …, соответственно;

12) термин «таблица» - используется  для обобщения таких видов  таблиц, как базовая_таблица, представление  или псевдоним; здесь псевдоним  служит для временного (на момент  выполнения запроса) переименования  и (или) создания рабочей копии базовой_таблицы (представления).

В дальнейшем все примеры  приводятся для базы данных приведенной  в приложении А.

Оператор SELECT осуществляет выборку из базы данных и имеет наиболее сложную структуру среди всех операторов языка SQL. Простейший оператор SELECT выглядит:

SELECT * FROM PC;

Он осуществляет выборку  всех записей из объекта БД табличного типа с именем PC. При этом столбцы  и строки результирующего набора не упорядочены. Чтобы упорядочить  поля результирующего набора, их следует перечислить через запятую в нужном порядке после слова SELECT:

SELECT price, speed, hd, ram, cd, model, code

FROM Pc;

В таблице 1 приводится результат  выполнения этого запроса.

Таблица 1 - Запрос SELECT

price

speed

hd

ram

cd

model

code

600.0

500

5

64

12x

1232

1

850.0

750

14

128

40x

1121

2

600.0

500

5

64

12x

1233

3

850.0

600

14

128

40x

1121

4

850.0

600

8

128

40x

1121

5

950.0

750

20

128

50x

1233

6

400.0

500

10

32

12x

1232

7

350.0

450

8

64

24x

1232

8

350.0

450

10

32

24x

1232

9

350.0

500

10

32

12x

1260

10

980.0

900

40

128

40x

1233

11


Вертикальную проекцию таблицы РC можно получить, если перечислить  только необходимые поля. Например, чтобы получить информацию только о  скорости процессора и объеме оперативной  памяти компьютеров, следует выполнить  запрос:3

SELECT speed, ram FROM PC;

который вернет следующие данные:

Таблица 2 - Запрос SELECT speed

speed

ram

500

64

750

128

500

64

600

128

600

128

750

128

500

32

450

64

450

32

500

32

900

128


Следует отметить, что  вертикальная выборка может содержать  дубликаты строк в том случае, если она не содержит потенциального ключа, однозначно определяющего запись. В таблице PC потенциальным ключом является поле code, которое выбрано в качестве первичного ключа таблицы. Поскольку это поле отсутствует в запросе, в приведенном выше результирующем наборе имеются дубликаты строк (например, строки 1 и 3). Если требуется получить уникальные строки (скажем, нас интересуют только различные комбинации скорости процессора и объема памяти, а не характеристики всех имеющихся компьютеров), то можно использовать ключевое слово DISTINCT:4

SELECT DISTINCT speed, ram FROM Pc;

что даст такой результат:

Таблица 3 - 1-й результат  запроса SELECT DISTINCT speed

speed

ram

450

32

450

64

500

32

500

64

600

128

750

128

900

128


Помимо DISTINCT может применяться  также ключевое слово ALL (все строки), которое принимается по умолчанию.

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

Так если требуется упорядочить  результирующий набор по объему оперативной  памяти в порядке убывания, можно записать:

SELECT DISTINCT speed, ram

FROM Pc

ORDER BY ram DESC

или

SELECT DISTINCT speed, ram

FROM Pc

ORDER BY 2 DESC

Результат, приведенный  ниже, будет одним и тем же.

Таблица 4  - 2-й результат  запроса SELECT DISTINCT speed

speed

ram

600

128

750

128

900

128

450

64

500

64

450

32

500

32


Сортировку можно проводить  по возрастанию (параметр ASC принимается  по умолчанию) или по убыванию (параметр DESC). Сортировка по двум полям:

SELECT DISTINCT speed, ram

FROM Pc

ORDER BY ram DESC, speed DESC

даст следующий результат:

Таблица 5 - 3-й результат  запроса SELECT DISTINCT speed

speed

ram

900

128

750

128

600

128

500

64

450

64

500

32

450

32


Горизонтальную выборку  реализует предложение WHERE , которое  записывается после предложения FROM. При этом в результирующий набор попадут только те строки из источника записей, для каждой из которых значение предиката равно TRUE. То есть предикат проверяется для каждой записи.

Предикаты представляют собой выражения, принимающие истинностное значение. Они могут представлять собой как одно выражение, так и любую комбинацию из неограниченного количества выражений, построенную с помощью булевых операторов AND, OR или NOT. Кроме того, в этих комбинациях может использоваться SQL-оператор IS, а также круглые скобки для конкретизации порядка выполнения операций.

Предикат в языке SQL может принимать одно из трех значений TRUE (истина), FALSE (ложь) или UNKNOWN (неизвестно). Исключение составляют следующие предикаты: NULL (отсутствие значения), EXISTS (существование), UNIQUE (уникальность) и MATCH (совпадение), которые не могут принимать значение UNKNOWN.

Правила комбинирования всех трех истинностных значений легче  запомнить, обозначив TRUE как 1, FALSE как 0 и UNKNOWN как 1/2 (где то между истинным и ложным).

AND с двумя истинностными  значениями дает минимум этих  значений. Например, TRUE AND UNKNOWN будет  равно UNKNOWN.

OR с двумя истинностными  значениями дает максимум этих  значений. Например, FALSE OR UNKNOWN будет  равно UNKNOWN.

Отрицание истинностного значения равно 1 минус данное истинностное значение. Например, NOT UNKNOWN будет равно UNKNOWN.

Помимо этого используются предикаты сравнения.

Предикат сравнения  представляет собой два выражения, соединяемых оператором сравнения. Имеется шесть традиционных операторов сравнения: =, >, <, >=, <=, <>.

Данные типа NUMERIC (числа) сравниваются в соответствии с их алгебраическим значением.

Данные типа CHARACTER STRING (символьные строки) сравниваются в  соответствии с их алфавитной последовательностью. Если a1a2…an и b1b2…bn - две последовательности символов, то первая "меньше" второй, если а1<b1, или а1=b1 и а2<b2 и т.д. Считается также, что а1а2…аn<b1b2…bm, если n<m и а1а2…аn=b1b2…bn, т.е. если первая строка является префиксом второй. Например, 'folder'<'for', т.к. первые две буквы этих строк совпадают, а третья буква строки 'folder' предшествует третьей букве строки 'for'. Также справедливо неравенство 'bar' < 'barber', поскольку первая строка является префиксом второй.5

Данные типа DATETIME (дата/время) сравниваются в хронологическом порядке.

Данные типа INTERVAL (временной  интервал) преобразуются в соответствующие  типы, а затем сравниваются как  обычные числовые значения типа NUMERIC.

Пример. Получить информацию о компьютерах, имеющих частоту  процессора не менее 500 Мгц и цену ниже $800:

SELECT * FROM Pc

WHERE speed >= 500 AND price < 800;

Запрос возвращает следующие  данные:

Таблица 6 - Пример информационного  запроса

code

model

speed

ram

hd

cd

price

1

1232

500

64

5

12x

600.0

3

1233

500

64

5

12x

600.0

7

1232

500

32

10

12x

400.0

10

1260

500

32

10

12x

350.0


Существуют так же и другие предикаты, например BETWEEN, IN, LIKE …

Имена столбцов, указанные  в предложении SELECT, можно переименовать. Это делает результаты более читабельными, поскольку имена полей в таблицах часто сокращают с целью упрощения набора. Ключевое слово AS, используемое для переименования, согласно стандарту можно и опустить, т.к. оно неявно подразумевается.

Например, запрос:

SELECT ram AS Mb, hd Gb

FROM Pc

WHERE cd = '24x';

переименует столбец ram в Mb (мегабайты), а столбец hd в Gb (гигабайты). Этот запрос возвратит объемы оперативной памяти и жесткого диска для тех компьютеров, которые имеют 24-скоростной CD-ROM:

Таблица 7 - Пример запроса SELECT AS

Mb

Gb

64

8

32

10


 

Получение итоговых значений:

Существует возможность  получения итоговых (агрегатных) функций. Стандартом предусмотрены следующие  агрегатные функции:

Таблица 8 - Описание (агрегатных) функции

Функция

Описание

COUNT(*)

Возвращает количество строк источника записей.

COUNT()

Возвращает количество значений в указанном столбце.

SUM()

Возвращает сумму значений в указанном столбце.

AVG()

Возвращает среднее  значение в указанном столбце.

MIN()

Возвращает минимальное  значение в указанном столбце.

MAX()

Возвращает максимальное значение в указанном столбце.


 

Все эти функции возвращают единственное значение. При этом функции COUNT, MIN и MAX применимы к любым типам  данных, в то время как SUM и AVG используются только для числовых полей. Разница  между функцией COUNT(*) и COUNT() состоит в том, что вторая при подсчете не учитывает NULL-значения.

Пример. Найти минимальную  и максимальную цену на персональные компьютеры:

SELECT MIN(price) AS Min_price, MAX(price) AS Max_price

FROM PC;

Результатом будет единственная строка, содержащая агрегатные значения:

Таблица 8 - Строка содержащая (агрегатные) значения

Min_price

Max_price

350.0

980.0


Для просмотра данных наиболее удобно использовать совместно  значения оператора COUNT - счетчик (позволяет узнать количество записей в запросе), и оператора CURSOR - позволяет принимать не все записи сразу а по одной (указанной пользователем).

 

1.4 Операторы модификации данных

 

Язык манипуляции данными (DML - Data Manipulation Language) помимо оператора SELECT, осуществляющего извлечение информации из базы данных, включает операторы, изменяющие состояние данных. Этими операторами являются:

INSERT Добавление записей (строк) в таблицу БД

UPDATE Обновление данных в столбце таблицы БД

DELETE Удаление записей из таблицы БД

1) Оператор INSERT.

Оператор INSERT вставляет новые строки в таблицу. При этом значения столбцов могут представлять собой литеральные константы либо являться результатом выполнения подзапроса. В первом случае для вставки каждой строки используется отдельный оператор INSERT; во втором случае будет вставлено столько строк, сколько возвращается подзапросом. 6

Синтаксис оператора:

INSERT INTO <имя таблицы>[(<имя столбца>,...)]    

{VALUES (< значение столбца>,…)}    

| <выражение запроса>    

| {DEFAULT VALUES};

Как видно из представленного синтаксиса, список столбцов не является обязательным. В том случае, если он отсутствует, список вставляемых значений должен быть полный, т.е. обеспечивать значения для всех столбцов таблицы. При этом порядок значений должен соответствовать порядку столбцов, заданному оператором CREATE TABLE для таблицы, в которую вставляются строки. Кроме того, каждое из этих значений должно быть того же типа (или приводиться к нему), что и тип, определенный для соответствующего столбца в операторе CREATE TABLE.

В качестве примера рассмотрим вставку строки в таблицу Product, созданную следующим оператором CREATE TABLE:

CREATE TABLE [dbo].[product] (    

[maker] [char] (1) NOT NULL ,    

[model] [varchar] (4) NOT NULL ,    

[type] [varchar] (7) NOT NULL )

Пусть требуется добавить в эту таблицу модель ПК 1157 производителя B. Это можно сделать следующим оператором:

INSERT INTO Product VALUES ('B', 1157, 'PC');

Если задать список столбцов, то можно  изменить "естественный" порядок  их следования:

INSERT INTO Product (type, model, maker) VALUES ('PC', 1157, 'B');

Казалось бы, это совершенно излишняя возможность, которая делает конструкцию  только более громоздкой. Однако она  становится выигрышной, если столбцы  имеют значения по умолчанию. Рассмотрим следующую структуру таблицы: