Управление умолчаниями

Управление умолчаниями. Умолчание default - это значение, которое будет присвоено столбцу таблицы при вставке строки, если в команде вставки явно не указано значение для этого столбца.

Как и правила, умолчания оставлены в SQL Server 2000 для обеспечения обратной совместимости с предыдущими версиями продукта до версии SQL Server 7.0 . Версия SQL Server 2000 позволяет задавать умолчания для столбцов таблицы или пользовательского типа данных при их создании, используя ключевое слово DEFAULT. Применение умолчаний и правил как отдельных объектов базы данных было вызвано невозможностью изменения таблиц до версии SQL Server 7.0. Было гораздо проще создать новое правило или умолчание, чем удалять таблицу и создавать ее заново.

Так как версии SQL Server 7.0 и 2000 разрешают свободно изменять структуру таблиц, то надобность в правилах и умолчаниях как отдельных объектах отпала сама собой. Поэтому, если вы еще только создаете собственную базу данных, нет необходимости использовать устаревшие конструкции, подобные правилам и умолчаниям.

К тому же нет абсолютно никакой гарантии, что 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