SQL Server 2
TOC \o "1-3" \h \zВведение. 2/a>
Краткая характеристика редакции. 8/a>
SQL Server 2. 8/a>
Enterprise Evaluation Edition. 9/a>
Взаимодействие с операционными системами. 11/a>
Взаимодействие с программным обеспечением Интернета. 12/a>
Планирование конфигурации сервера. 13/a>
Автоматическая установка. 18/a>
Создание учетных записей. 19/a>
Установка сетевых библиотек и протоколов. 25/a>
Установка сетевых протоколов в Windows 2. 25/a>
Сетевая библиотек Описание. 26/a>
Установка и конфигурирование клиентов. 27/a>
Запуск, остановка и приостановка служб. 29/a>
Ручной запуск SQL Server 31/a>
Запуск SQL Server в однопользовательском режиме. 32/a>
Запуск SQL Server с минимальными требованиями. 32/a>
Дополнительные режимы запуска. 33/a>
Общие правила разграничения доступа. 36/a>
Архитектура системы безопасности SQL Server 2. 37/a>
Режим аутентификации SQL Server 38/a>
Компоненты структуры безопасности. 39/a>
Ограничение доступа к файлам SQL Server 46/a>
Права на доступ к объектам баз данных. 47/a>
Создание и обслуживание баз данных. 50/a>
Использование неформатированных разделов 51/a>
Использование Transact-SQL.. 53/a>
Управление базами данных. 57/a>
Уменьшение размера базы данных. 60/a>
Управление свойствами базы данных. 64/a>
Присоединение и отсоединение базы данных. 67/a>
Изменение имени базы данных. 69/a>
Просмотр свойств базы данных. 69/a>
Управление пользовательскими типами данных. 76/a>
/h1>
Управление молчаниями
Умолчание (default) - это значение, которое будет присвоено столбцу таблинцы при вставке строки, если в команде вставки явно не казано значение для этого столбца.
Как и правила,
умолчания оставлены в SQL Server 2 для обеспечения обратной совместимости с предыдущими версиями продукта (до версии SQL Server 7.0). Версия SQL Server 2 позволяет задавать молчания для столбнцов таблицы или пользовательского типа данных при их создании, используя ключевое слово DEFAULT. Применение молчаний и правил как отдельных объекнтов базы данных было вызвано невозможностью изменения таблиц до версии SQL Server 7.0. Было гораздо проще создать новое правило или умолчание, чем далять таблицу и создавать ее заново. Так как версии SQL Server 7.0 и 2 разрешают свободно изменять структуру таблиц, то надобность в правилах и молчаниях как отдельных объектах отпала сама собой. Поэтому, если вы еще только создаете собственную базу данных, нет необходимости использовать устаревшие конструкции, подобные правилам и молчаниям. К тому же нет абсолютно никакой гарантии, что Microsoft будет поддерживать эти объекты в следующих реализациях SQL Server, так что при использовании правил и молчаний перед вами рано или поздно встанет вопрос об изменении структунры базы данных.
Сейчас мы рассматриваем молчания, которые существуют в базе данных как самостоятельные объекты. молчания предоставляют добный способ быснтро назначать одинаковые значения по молчанию множеству столбцов таблиц базы данных. Тем не менее задавать значения по умолчанию для столбцов реконмендуется,
используя синтаксис команд CREATE TABLE и ALTER
TABLE.
Созданное умолчание само по себе не выполняет никаких действий. Его ненобходимо связать с каким-нибудь столбцом таблицы или пользовательским тинпом данных. Тип данных умолчания должен соответствовать типу данных, становленному для столбца, с которым связывается молчание.
Для создания умолчания используется следующая команда: CREATE DEFAULT default AS
constant_expression
Здесь defaultЧ имя молчания, a constant_express1on - его значение.
При выборе имени умолчания следует придерживаться становленных пранвил именования объектов.
Кроме того, имя молчания должно быть никально для каждого владельца. казание имени владельца молчания при его создании не обязательно.
В качестве значения constant_expression можно использовать не только коннстанты, но и любые математические выражения и встроенные функции.
Строки символов и даты должны заключаться в одиночные кавычки. Перед бинарными данными должен казываться префикс Ох, перед денежным типом - символ $. Если размер значения по молчанию превышает размер, заданный для данных в столбце, выполняется сечение значения по умолчанию до требуемого размера.
Приведем пример создания текстового молчания: CREATE DEFAULT default one AS
"RIAC Industries"
Создание молчания не может выполняться в одном пакете с другими командами
Transact-SQL.
Умолчание может быть создано только в текущей базе данных. После того как молчание создано, его можно связать со столбцом таблицы или пользовательнским типом данных. Для связывания молчания с объектом базы данных испольнзуется хранимая процедура sp_bindefault, имеющая следующий синтаксис:
sp_bindefaultа [@defname
=] "default",
[(Pobjname =] "objectjiame"
[.
[@future]only =] "futureonly_flag"]
Здесь используются следующие аргументы.
О "default" - имя умолчания. Это имя, казанное при создании молчанния в команде CREATE DEFAULT.
О "object_name" - имя объекта, к которому привязывается молчание. Для свянзывания молчания со столбцом таблицы имя объекта казывается в форме col umn. tab!
e. Если же используется другая форма имени, то считается, что молчание связывается с пользовательским типом данных. молчание не монжет быть связано со столбцом типа timestamp, столбцом с установленным огнраничением целостности IDENTITY или со столбцом, связанным с другим молнчанием. В последнем случае необходимо отвязать от столбца старое умолчание, же затем привязывать новое. Если умолчание связывается со столбцом, именющим пользовательский тип данных, и с этим типом данных связано другое молчание, то молчание, определенное для столбца, имеет приоритет над умолнчанием,
установленным для пользовательского типа данных. Если в имени объекта присутствуют недопустимые символы, то в аргументе ob ject_name ненобходимо использовать разделители [ и ] для казания имени объекта.
О "futureonly_flag" - этот аргумент требуется только при связывании молнчания с пользовательским типом данных и не нужен при связывании со столб-
цом таблицы. При казании этого аргумента в столбцы, имеющие пользовантельский тип данных, с которым связывается молчание, не будет внесено никаких изменений. Если же аргумент f utureonl у не указывается, то для всех столбцов пользовательского типа данных применяется значение по молчанию, связанное с этим типом данных. Пример связывания молчания со столбцом таблицы:
ЕХСа sp_b1ndefault
"default_one",
"[employes 013].[company
name]"
Пример связывания молчания с пользовательским типом данных:
ЕХЕС sp_bindefault
"default_one".
"emp_data".
"futureonly"
Если тип данных,
определенный в молчании, не соответствует типу данных, определенному для связанного столбца, то при попытке вставки строки в таблицу сервер выдаст сообщение об ошибнке. При связывании молчания со столбцом таблицы сообщение о несоответствии типов не выданется, и связывание проходит спешно.
Когда молчание связывается со столбцом таблицы, информация о связывании сохраняется в системной таблице базы данных syscolumns. При связывании молнчания с пользовательским типом данных информация сохраняется в таблице systypes.
Если молчание связывается со столбцом таблицы или пользовательским типом данных, для которых определено правило, то следует убедиться, что молнчание не конфликтует с правилом. В противном случае сервер будет выдавать сообщение об ошибке всякий раз при добавлении в таблицу новой строки без казания значения для столбца. При связывании правила и умолчания со столбнцом сервер не отслеживает возможность подобных конфликтов,
поэтому админнистратор должен сам позаботиться об их отсутствии.
При вставке новой строки без казания значений для столбцов этим столбнцам присваивается либо значение по молчанию
(если таковое определено), либо значение
NULL (если для столбца разрешено хранение значений NULL). Если для столбца не определено значение по молчанию и запрещено хранение значений NULL, то при вставке пустой строки сервер выдаст сообщение об ошибке. Если для столбца разрешено хранение значений NULL и становлено значение по молнчанию, то при вставке пустой строки значение по умолчанию будет иметь приноритет над значением NULL.
Для даления умолчания из базы данных используется следующая команда: DROP DEFAULT {default} [,...n]
Здесь аргумент default определяет имя молчания, которое необходимо данлить. Используя одну команду DROP DEFAULT, можно далить несколько молнчаний. Для этого необходимо перечислить их через запятую.
Нельзя далить молчание, связанное со столбцом таблицы или пользовательнским типом данных. Перед далением необходимо отвязать молчание от всех объекнтов, же затем выполнять команду DROP DEFAULT. Для отвязывания молчания используется хранимая процедура sp_unbindefault со следующим синтаксисом:
sp_unbindefault [@objname
=] "object_name"
[, [@futureonlу =] "futureonly_flag"]
Здесь используются следующие аргументы.
О "object_name" - имя столбца таблицы или пользовательского типа данных, от которых необходимо отвязать молчание. Когда молчание отвязывается от пользовательского типа данных, оно автоматически отвязывается ото всех столбцов,
имеющих этот тип данных, если только молчание не было связанно с этими столбцами явно и в команде не казан аргумент "futureonly".
О " f utureonl y_f 1 ag" - казывается только для пользовательских типов данных. Если этот аргумент имеет значение "futureonly", то молчание не отвязыванется от столбцов, имеющих пользовательский тип данных. Если этот аргумент отсутствует, сервер автоматически отвяжет молчание от всех столбцов. Для получения сведений о представлении (имени владельца и даты созданния) используйте хранимую процедуру sp_help с казанием в качестве аргунмента имени молчания: spjielpа
"default_one"
Для получения текста кода Transact-SQL, определяющего молчание, испольнзуйте хранимую процедуру sp_helptext: sp_helptextа "default_one"
Для изменения имени умолчания используйте хранимую процедуру sp_rename: sp_rename @objname='defaul t_one'а @newname='default_two'
Список литературы
- Мамаев
Е., Шкарина Л. Microsoft
SQl Server 2 для профессионалов.-Пб:Питер, 2001
- Хоторн
Роб Разработка баз данных, Micrososoft
SQL Server 2.-Вильямс, 2001
- Шарон
Б., Мэйбл Грэг Sql
Server 2, Энциклопедия программиста.-ДиСофт, 2001
Умолчание (default) - это значение, которое будет присвоено столбцу таблинцы при вставке строки, если в команде вставки явно не казано значение для этого столбца.
Как и правила, умолчания оставлены в SQL Server 2 для обеспечения обратной совместимости с предыдущими версиями продукта (до версии SQL Server 7.0). Версия SQL Server 2 позволяет задавать молчания для столбнцов таблицы или пользовательского типа данных при их создании, используя ключевое слово DEFAULT. Применение молчаний и правил как отдельных объекнтов базы данных было вызвано невозможностью изменения таблиц до версии SQL Server 7.0. Было гораздо проще создать новое правило или умолчание, чем далять таблицу и создавать ее заново. Так как версии SQL Server 7.0 и 2 разрешают свободно изменять структуру таблиц, то надобность в правилах и молчаниях как отдельных объектах отпала сама собой. Поэтому, если вы еще только создаете собственную базу данных, нет необходимости использовать устаревшие конструкции, подобные правилам и молчаниям. К тому же нет абсолютно никакой гарантии, что Microsoft будет поддерживать эти объекты в следующих реализациях SQL Server, так что при использовании правил и молчаний перед вами рано или поздно встанет вопрос об изменении структунры базы данных.
Сейчас мы рассматриваем молчания, которые существуют в базе данных как самостоятельные объекты. молчания предоставляют добный способ быснтро назначать одинаковые значения по молчанию множеству столбцов таблиц базы данных. Тем не менее задавать значения по умолчанию для столбцов реконмендуется, используя синтаксис команд CREATE TABLE и ALTER TABLE.
Созданное умолчание само по себе не выполняет никаких действий. Его ненобходимо связать с каким-нибудь столбцом таблицы или пользовательским тинпом данных. Тип данных умолчания должен соответствовать типу данных, становленному для столбца, с которым связывается молчание.
Для создания умолчания используется следующая команда: CREATE DEFAULT default AS constant_expression
Здесь defaultЧ имя молчания, a constant_express1on - его значение.
При выборе имени умолчания следует придерживаться становленных пранвил именования объектов. Кроме того, имя молчания должно быть никально для каждого владельца. казание имени владельца молчания при его создании не обязательно.
В качестве значения constant_expression можно использовать не только коннстанты, но и любые математические выражения и встроенные функции. Строки символов и даты должны заключаться в одиночные кавычки. Перед бинарными данными должен казываться префикс Ох, перед денежным типом - символ $. Если размер значения по молчанию превышает размер, заданный для данных в столбце, выполняется сечение значения по умолчанию до требуемого размера.
Приведем пример создания текстового молчания: CREATE DEFAULT default one AS "RIAC Industries"
Создание молчания не может выполняться в одном пакете с другими командами Transact-SQL.
Умолчание может быть создано только в текущей базе данных. После того как молчание создано, его можно связать со столбцом таблицы или пользовательнским типом данных. Для связывания молчания с объектом базы данных испольнзуется хранимая процедура sp_bindefault, имеющая следующий синтаксис:
sp_bindefaultа [@defname =] "default",
[(Pobjname =] "objectjiame"
[. [@future]only =] "futureonly_flag"]
Здесь используются следующие аргументы.
О "default" - имя умолчания. Это имя, казанное при создании молчанния в команде CREATE DEFAULT.
О "object_name" - имя объекта, к которому привязывается молчание. Для свянзывания молчания со столбцом таблицы имя объекта казывается в форме col umn. tab! e. Если же используется другая форма имени, то считается, что молчание связывается с пользовательским типом данных. молчание не монжет быть связано со столбцом типа timestamp, столбцом с установленным огнраничением целостности IDENTITY или со столбцом, связанным с другим молнчанием. В последнем случае необходимо отвязать от столбца старое умолчание, же затем привязывать новое. Если умолчание связывается со столбцом, именющим пользовательский тип данных, и с этим типом данных связано другое молчание, то молчание, определенное для столбца, имеет приоритет над умолнчанием, установленным для пользовательского типа данных. Если в имени объекта присутствуют недопустимые символы, то в аргументе ob ject_name ненобходимо использовать разделители [ и ] для казания имени объекта.
О "futureonly_flag" - этот аргумент требуется только при связывании молнчания с пользовательским типом данных и не нужен при связывании со столб-
цом таблицы. При казании этого аргумента в столбцы, имеющие пользовантельский тип данных, с которым связывается молчание, не будет внесено никаких изменений. Если же аргумент f utureonl у не указывается, то для всех столбцов пользовательского типа данных применяется значение по молчанию, связанное с этим типом данных. Пример связывания молчания со столбцом таблицы:
ЕХСа sp_b1ndefault "default_one",
"[employes 013].[company name]"
Пример связывания молчания с пользовательским типом данных:
ЕХЕС sp_bindefault "default_one".
"emp_data". "futureonly"
Если тип данных, определенный в молчании, не соответствует типу данных, определенному для связанного столбца, то при попытке вставки строки в таблицу сервер выдаст сообщение об ошибнке. При связывании молчания со столбцом таблицы сообщение о несоответствии типов не выданется, и связывание проходит спешно.
Когда молчание связывается со столбцом таблицы, информация о связывании сохраняется в системной таблице базы данных syscolumns. При связывании молнчания с пользовательским типом данных информация сохраняется в таблице systypes.
Если молчание связывается со столбцом таблицы или пользовательским типом данных, для которых определено правило, то следует убедиться, что молнчание не конфликтует с правилом. В противном случае сервер будет выдавать сообщение об ошибке всякий раз при добавлении в таблицу новой строки без казания значения для столбца. При связывании правила и умолчания со столбнцом сервер не отслеживает возможность подобных конфликтов, поэтому админнистратор должен сам позаботиться об их отсутствии.
При вставке новой строки без казания значений для столбцов этим столбнцам присваивается либо значение по молчанию (если таковое определено), либо значение NULL (если для столбца разрешено хранение значений NULL). Если для столбца не определено значение по молчанию и запрещено хранение значений NULL, то при вставке пустой строки сервер выдаст сообщение об ошибке. Если для столбца разрешено хранение значений NULL и становлено значение по молнчанию, то при вставке пустой строки значение по умолчанию будет иметь приноритет над значением NULL.
Для даления умолчания из базы данных используется следующая команда: DROP DEFAULT {default} [,...n]
Здесь аргумент default определяет имя молчания, которое необходимо данлить. Используя одну команду DROP DEFAULT, можно далить несколько молнчаний. Для этого необходимо перечислить их через запятую.
Нельзя далить молчание, связанное со столбцом таблицы или пользовательнским типом данных. Перед далением необходимо отвязать молчание от всех объекнтов, же затем выполнять команду DROP DEFAULT. Для отвязывания молчания используется хранимая процедура sp_unbindefault со следующим синтаксисом:
sp_unbindefault [@objname =] "object_name"
[, [@futureonlу =] "futureonly_flag"]
Здесь используются следующие аргументы.
О "object_name" - имя столбца таблицы или пользовательского типа данных, от которых необходимо отвязать молчание. Когда молчание отвязывается от пользовательского типа данных, оно автоматически отвязывается ото всех столбцов, имеющих этот тип данных, если только молчание не было связанно с этими столбцами явно и в команде не казан аргумент "futureonly".
О " f utureonl y_f 1 ag" - казывается только для пользовательских типов данных. Если этот аргумент имеет значение "futureonly", то молчание не отвязыванется от столбцов, имеющих пользовательский тип данных. Если этот аргумент отсутствует, сервер автоматически отвяжет молчание от всех столбцов. Для получения сведений о представлении (имени владельца и даты созданния) используйте хранимую процедуру sp_help с казанием в качестве аргунмента имени молчания: spjielpа "default_one"
Для получения текста кода Transact-SQL, определяющего молчание, испольнзуйте хранимую процедуру sp_helptext: sp_helptextа "default_one"
Для изменения имени умолчания используйте хранимую процедуру sp_rename: sp_rename @objname='defaul t_one'а @newname='default_two'
Список литературы
- Мамаев Е., Шкарина Л. Microsoft SQl Server 2 для профессионалов.-Пб:Питер, 2001
- Хоторн Роб Разработка баз данных, Micrososoft SQL Server 2.-Вильямс, 2001
- Шарон Б., Мэйбл Грэг Sql Server 2, Энциклопедия программиста.-ДиСофт, 2001