SQL Server 2000
Страница 43

Этапу создания непосредственно предшествует фаза планирования, которая включает в себя про­ектирование состава файлов и групп файлов, из которых будет состоять база данных. Это плани­рование физической части. Неотъемлемой частью процесса создания базы данных является и планирование логической архитектуры, в которую входит проектирование таблиц с использовани­ем нормализации. Однако создание собственно базы данных не требует предварительного проек­тирования таблиц.

Итак, начнем рассмотрение работы с базами данных с ее создания. В Transact-SQL создание базы данных выполняется с помощью команды CREATE DATABASE, имеющей следующий синтаксис:

CREATE DATABASE databasejiame

[ ON [ PRIMARY ]

[ < filespec > [ n ] ]

[ , < filegroup > [ , .n ] ]

]

[ LOG ON { < filespec > [ , .n ] } ]

[ COLLATE collationjiame ]

[ FOR LOAD | FOR ATTACH ]

Рассмотрим подробно назначение каждого из аргументов. О database_name. С помощью этого аргумента указывается имя, которое будет присвоено создаваемой базе данных. При выборе имени следует следовать общим правилам именования объектов. Если имя базы данных содержит пробелы или другие недопустимые символы, оно должно быть заключено в огра­ничители (двойные кавычки или квадратные скобки). Имя базы данных дол­жно быть уникальным в пределах сервера и не может превышать 128 симво­лов. Если имя журнала транзакций явно не указано, то сервер укорачивает имя базы данных таким образом, чтобы оно не превышало 123 символов. Это делается из-за того, что сервер по умолчанию использует для имени журна­ла транзакций имя базы данных и добавляет к нему в конце символы _Log.

О О N. Это ключевое слово означает, что далее следует определение файлов базы данных.

О PRIMARY. Это ключевое слово означает, что далее следует описание первично­го файла базы данных. Напомним, что в этом файле хранятся все системные данные и таблицы. Только один файл в базе данных может быть определен как первичный. Если первичный файл не определен явно, то в этом качестве будет использоваться первый файл, указанный в конструкции <f i I espeo. Груп­па файлов, в которую включен первичный файл, называется первичной груп­пой файлов (primary file group). Первичная группа назначается группой файлов по умолчанию (default file group), и в нее будут включены все файлы, для ко­торых явно не указана пользовательская группа файлов (user file group).

О LOG ON. Это ключевое слово означает, что файлы журнала транзакций будут определены явно. После LOG ON должно следовать определение файлов жур­нала транзакций. Если это ключевое слово не используется, то есть пользо­ватель не задает явно файлы журнала транзакций, то сервер автоматически создает единственный файл размером 25% от общей суммы размеров файлов данных. Имя файла генерируется на основе имени базы данных, но в конце к нему добавляются символы _Log.

О FOR LOAD. Этот аргумент оставлен в большей степени для обеспечения обрат­ной совместимости с предыдущими версиями SQL Server (до SQL Server 7.0). Он предписывает серверу создать базу данных в режиме использования толь­ко владельцем (dbo use only). Это делается, если необходимо выполнить вос­становление базы данных из резервной копии. Дело в том, что в ранних вер­сиях SQL Server восстановление базы данных было возможно только в уже существующую базу данных, установленную в режим FOR LOAD. Начиная с SQL Server 7.0, при необходимости база данных может быть создана автоматически в ходе выполнения команды RESTORE. Более того, допускается восстановление резервной копии поверх существующей базы данных.

О FOR ATTACH. Этот аргумент используется, когда необходимо выполнить присое­динение (attach) базы данных. В этом случае на диске уже должны существо­вать файлы с данными. Таким образом, создание базы данных происходит только на логическом уровне — в системную таблицу sysdatabases базы дан­ных master вносятся соответствующие записи, но создание собственно фай­лов не выполняется. Для подключения базы данных бывает достаточно ука­зать только размещение первичного файла базы данных. Информация о местоположении всех других файлов базы данных (вторичных и журнала тран­закций) хранится в первичном файле базы данных. Однако если местополо­жение файлов базы данных с момента ее отсоединения изменилось, то необ­ходимо будет указать полный путь к каждому файлу базы данных.

Страницы: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63