План занятия
Теоретические сведения
Пример.
Create table Test_table
(
id int identity(1,1) not null primary key,
name varchar(25),
surname varchar(25),
rights varchar(20) not null default 'user'
)
После этого запроса будет создана таблица с ключевым полем id, необязательными полями
name и surname и обязательным полем rights, со значением по умолчанию user.
Для просмотра списка таблиц и получения информации о таблицах существует служебная
хранимая процедура SP_HELP
При вызове:
Execute sp_help
на экране появится список всех таблиц и представлений, которые есть в активной базе
данных.
Например, давайте просмотрим таблицы базы данных Library.
Если после SP_HELP указать имя таблицы, то на экран выведется служебная информация о
этой таблице.
Как видите, в полученной таблице указывается название таблицы, владелец, дата создания,
типы столбцов, в общем, вся информация, которая может вас заинтересовать по структуре
таблицы.
Ограничения.
При создании таблиц иногда возникает необходимость указать для поля определенные
ограничения. Например, чтобы в поле, хранящее возраст нельзя было сохранить значение
больше 100, либо при помощи запроса создать связь между двумя таблицами. Все это
подпадает под понятие Ограничения и будет рассмотрено в этой главе.
Ограничения можно поделить на такие группы:
1. Ограничение Первичный Ключ.
2. Ограничение по Умолчанию.
3. Ограничение на Проверку.
4. Ограничение Уникальности.
5. Ограничение Внешний Ключ.
Наверное у вас возник вопрос, а где их можно просмотреть. Все что нужно сделать - это
вызвать процедуру sp_help по отношению к интересующей вас таблице и вы получите список
ограничений, которые наложены на ее поля.
Относительно таблицы, которую создавали в предыдущей главе и списка ограничений можно
сделать вывод, что автоматически установленных ограничений несколько. Первое - поле id
имеет ограничение первичный Ключ. Второе ограничение - поле rights имеет параметр по
умолчанию. Давайте посмотрим, что об этом говорит процедура sp_help.
Либо
Т.о. мы получаем таблицу, у которой составной первичный ключ состоит из полей name и
project.
Ограничение по Умолчанию.
Ограничение по умолчанию можно тоже установить, дав ему при этом указанное вами, а не
SQL Server имя.
Ограничение на Проверку.
Ограничение на проверку определяет, что прежде чем записать данные в ячейку, будет
произведена проверка того условия, которое указано в ограничении.
Так вы определите, что значение, которое заносится в col2 должно быть больше, чем значение
в col1, но меньше, чем значение в col3.
Ограничение Уникальности.
Существует возможность указать, что значения в поле не должны повторяться.
Если, после того, как вы выполнили запрос, указав при этом связи, создавать Диаграмму, то
прописанные связи будут прорисованы автоматически.
Модификация таблиц. Оператор ALTER TABLE.
Представьте, что создавая таблицу вы допустили некритическую ошибку, запрос отработал, но
имя поля, которое должно было иметь тип данных decimal имеет тип данных int. Вроде бы
ничего страшного, а удалять таблицу, а потом создавать ее заново не самый рациональный
способ (особенно если в таблице уже есть данные). Иногда нужно добавить определенное
поле, либо, наоборот, удалить, причем так, чтобы это было наименее болезненно. Для этого и
служит оператор Alter Table, который служит для изменения структуры таблицы.
Для модифицирования схемы таблицы применяется инструкция ALTER TABLE. Язык Transact-
SQL позволяет осуществлять следующие виды изменений таблиц:
добавлять и удалять столбцы;
изменять свойства столбцов;
добавлять и удалять ограничения для обеспечения целостности;
разрешать или отключать ограничения;
переименовывать таблицы и другие объекты базы данных.
Общий синтаксис:
Alter table Имя_таблицы
{
[Add имя_поля спецификаторы --Добавление стобца]
[Alter Column имя_поля новые_спецификаторы --модифицирование столбца]
[Drop имя_поля --удаление столбца]
[Drop Constraint имя_ограничения --удаление ограничения]
[Add Constraint имя_ограничения имя_ограничения тип_ограничения]
}
Добавление поля.
Предположим, что у вас есть таблица Table и вам необходимо добавить поле Hello. Тогда
запрос будет такой:
Вы должны помнить, что поле со спецификатором NOT NULL может быть добавлено только
если также будет указано ограничение по Умолчанию.
Добавление ограничений.
Конечно же, если вы забыли указать ограничение при создании таблицы, то вы можете это
сделать при помощи Alter table.
Например, вам необходимо указать значение по умолчанию для поля Col1 таблицы Table2.
Как видите, необходимо использовать ключевое слово for, чтобы указать столбец, которому
указывается ограничение. Для добавления ограничений на первичный ключ, уникальные
значения и внешний ключ этого делать не нужно.
После этого запроса создастся представление MyView1. Увидеть его можно при помощи
процедуры SP_HELP.
Положительная сторона работы с представлениями состоит в том, что по отношению к ним
можно делать запросы на выборку, а также запросы на обновление информации, тем самым,
изменяя структуру той таблицы, данные из которой находятся в представлении.
Например, чтобы просмотреть содержимое созданного представления достаточно сделать
запрос типа:
Select *
From MyView1
Результат:
Теперь на много облегчается процесс написания запросов.
Select *
From MyView1
Where datein is not null
Результат:
Есть еще окно колоссальное преимущество представлений. До сих пор, при помощи Group By
можно было показывать список чего-либо. А что делать, если к этому списку необходимо
вызвать какую-либо функцию агрегирования? Указать запрос, в качестве таблицы, из которой
должна производиться вычитка, нельзя. Выход здесь единственный - на основе запроса с Group
By создать представление, а уже по отношению к представлению делать запрос.
Задача - показать издательство, издавшее наибольшее кол-во страниц.
ОШИБКА!!!
Select max(MySum1)
From (
Select sum(books.pages) as MySum1, press.name
from books,press
where books.id_press=press.id
group by press.name
)
Правильно!!!
Create View MyView2 as
Select sum(books.pages) as MySum1, press.name
from books,press
where books.id_press=press.id
group by press.name
Результат:
Модификация Представлений.
Модификация представлений осуществляется при помощи все того же ключевого слова Alter.
Общий синтаксис:
Если вы заметили, то вся разница лишь в том, что слово Create заменено на Alter. Но Alter View
использовать лучше в том случае, если вы заботитесь о раздаче прав. Если удалить
представление, то все права на него аннулируются и после повторного создания нужно будет
настраивать их заново, а Alter View позволяет изменить представление, и оставить права на
него не тронутыми.
Удаление Представлений.
Удаление представления производится при помощи ключевого слова Drop. Общий синтаксис:
Будет создано представление, в котором будет список студентов, имена у которых начинается
с буквы А. Если после этого будет произведена попытка добавления данных, то, учитывая что
указано With Check Option, добавлять можно будет только людей, у которых имя начинается с
буквы А.