Автоматическое создание статистики
Автоматическое обновление статистики
Автоматическое закрытие базы данных
Автоматическое сжатие базы данных
Разрешение значения NULL по умолчанию для столбца
Управление сравнением величин NULL
Появление сообщений об ошибке
Значение ON означает, что результатом объединения величин NULL будет значение NULL
Закрытие курсора при завершении транзакции
Использование базы данных только владельцем
Создание по умолчанию локального курсора
База данных может публиковаться для репликации сведением
Отключение базы данных
Разрешение публикации базы данных
Разрешение использования двойных кавучек для указания идентификаторов
Использование базы данных только для чтения Разрешение выполнения вложенных триггеров
Разрешение выполнения команд копирования, не регистрируемых
в журнале транзакций _
продолжение А
данных
Таблица (продолжение)
Параметр Назначение
subscribed Разрешение подписки на публикацию single user Использование базы данных в режиме поддержки одного пользователя
torn page detection Обнаружение поврежденных страниц
trunc. log on chkpt Усечение журнала транзакций при выполнении контрольной точки
Например, для переключения базы данных pubs в однопользовательский режим нужно выполнить следующую команду: ЕХЕС sp_dboption "pubs", "single user", "true"
Часть установленных администратором параметров конфигурации базы данных может быть изменена пользователем с помощью команды SET на уровне соединения, транзакции, хранимой процедуры, пакета команд и т. д. Эти изменения действуют только в пределах соединения (транзакции, хранимой процедуры и т. д.) и будут потеряны сразу же после отсоединения пользователя. При последующем соединении снова будут использоваться параметры, установленные администратором.
Использование системной хранимой процедуры sp_dboption для управления свойствами базы данных было единственным вариантом в предыдущих версиях. Даже при работе с SQL Server 7.0 администратор имел в своем распоряжении только эту процедуру. В SQL Server 2000 изменение параметров базы данных также может выполняться с помощью команды ALTER DATABASE с аргументом SET <optionspec>. Как нетрудно догадаться, свойства базы данных, которые предполагается изменить, указываются с помощью конструкции <optionspec>, имеющей следующий синтаксис:
<opt1onspec>::=
< state_option >
[ < cursor_option >
| < auto_option >
| < sql_option >
| < recovery_option >
< state_option > .- .- =
{ SINGLEJJSER | RESTRICTED_USER | MULTIUSER }
| { OFFLINE | ONLINE }
| { READJ3NLY | READ_WRITE }
< termination >
ROLLBACK AFTER integer [ SECONDS ]
| ROLLBACK IMMEDIATE
| NO WAIT
< cursor_option > : : =
CURSOR_CLOSE_ON_COMMIT { ON | OFF }
| (CURSOR_DEFAULT { LOCAL | GLOBAL }
< auto_option >
{ AUTO_CLOSE ON | OFF }
| { AUTO_CREATE_STATISTICS ON | OFF }
| { AUTO_SHRINK ON | OFF }
| { AUTO_UPDATE_STATISTICS ON | OFF }
< sql_option > ::=
ANSI_NULL_DEFAULT { ON | OFF }
| ANSI_NULLS { ON | OFF }
j ANSI_PADDING { ON | OFF }
j ANSIJIARNINGS { ON | OFF }
| ARITHABORT { ON | OFF }
| CONCAT_NULL_YIELDS_NULL { ON | OFF }
| NUMERIC_ROUNDABORT { ON | OFF }
| QUOTEDJDENTIFIER { ON J OFF }
| RECURSIVEJRIGGERS { ON | OFF }
< recovery_option > ::=
RECOVERY { FULL | BULK_LOGGED | SIMPLE }
| TORN_PAGE_DETECTION { ON | OFF }
Практически все перечисленные аргументы были рассмотрены либо в этой главе, либо в главе 11. Поэтому мы не будет лишний раз на них останавливаться.
Присоединение и отсоединение базы данных
SQL Server 2000 позволяет отсоединять (detach) базы данных от сервера. Пользователи не могут обращаться к отсоединенным базам данных. Описание отсоединенной базы данных, включая описание файлов журнала транзакций и самой базы данных, удаляется из системных таблиц SQL Server и, таким образом, сервер перестает ее воспринимать. Позже эту базу данных можно присоединить (attach) на этом же или другом сервере.