SQL Server 2000
е останова
SQL Server 2000 файлы баз данных могут быть скопированы безо всяких
затруднений.
Я отдельно отметил, что для копирования файлов баз данных необходимо
остановить SQL Server 2000, а точнее, службу MSSQLServer. В противном
случае файлы баз данных блокируются и к ним не удастся получить доступ.
При наличии неформатированных разделов скопировать данные будет
практически невозможно, так как в операционных системах семейства Windows
не реализованы механизмы работы с неформатированными разделами. Если вы
хотите обеспечить максимальную конфиденциальность информации, то
возможность использования неформатированных разделов является довольно
мощным инструментом решения задачи. В этом случае рекомендуется создать
базу данных из одного файла данных, расположенного на неформатированном
разделе. В идеале файлы журнала транзакций также могут быть расположены
на неформатированных разделах. Однако отметим, что для каждого файла базы
данных потребуется отдельный неформатированный раздел.
Увеличение базы данных
По мере того как пользователи вносят информацию в базу данных, количество
свободного пространства в ней уменьшается. Когда все свободное
пространство исчерпано, сервер выдает сообщение об ошибке с номером 1105.
В предыдущих версиях SQL Server необходимо было вручную добавлять новое
свободное пространство в базу данных, сначала создавая новые устройства
или расширяя существующие, а затем увеличивая саму базу данных или журнал
транзакций. Начиная с SQL Server 7.0, реализована возможность
автоматического увеличения размеров базы данных (auto grow). Эта
возможность реализуется на уровне файлов базы данных, для которых можно
разрешить автоматическое увеличение размера при полном заполнении базы
данных. Если возможности автоматического роста исчерпаны (например,
кончилось свободное место на диске или размер файла достиг максимальной
величины) или поддержка автоматического увеличения файлов вообще не была
задействована, то администратор должен вручную увеличить размер базы
данных (expanding database). Для этого он либо увеличивает размер
существующих файлов, либо создает новые файлы. Это касается как файлов
самой базы данных, так и файлов журнала транзакций.
Особенное внимание администратор должен уделить системной базе данных
tempdb, в которой создаются все временные объекты. По умолчанию максималь-
,ный размер файлов базы данных не ограничен. Тем не менее, если места на
диске мало, то через какое-то время возможности увеличения базы данных
tempdb будут исчерпаны. Сервер не сможет создавать временные объекты и,
следовательно, пользователи не смогут успешно работать с любой базой
данных, расположенной на этом сервере. Администратор должен своевременно
отслеживать наличие необходимого свободного пространства и при
необходимости добавлять к базе данных файлы, расположенные на дисках с
достаточным количеством свободного пространства.
Использование Transact-SQL
В этой главе подробно рассматриваются различные аспекты создания баз
данных и управления ими в SQL Server 2000. Как уже было сказано, для
работыс базами данных в SQL Server 2000 могут быть использованы различные
средства — мастер Create Database Wizard, утилита Enterprise Manager и
команды Transact-SQL. В этом разделе мы познакомимся с созданием и
изменением баз данных, а также с управлением базами данных средствами
Transact-SQL. Этот метод является наиболее сложным из всех перечисленных,
но обладает максимальными возможностями. В сущности, два других метода
предоставляют всего-навсего графических интерфейс для выполнения
соответствующих системных хранимых процедур.
Для эффективного управления базами данных SQL Server 2000 вовсе не
обязательно виртуозно владеть системными хранимыми процедурами. В
большинстве случаев вполне достаточно средств, предлагаемых Enterprise
Manager. Тем не менее истинный профессионал должен уметь добиться нужного
результата и в том случае, когда в его распоряжении имеются лишь простые
средства выполнения запросов, а использование красивых графических
оболочек вроде Enterprise Manager по тем или иным причинам оказывается
невозможным.
Создание баз данных
Первое, с чем сталкивается администратор при реализации базы данных, это
ее создание. Казалось бы, что может быть проще, чем указать имя базы
данных, и на этом дело бы закончилось. Однако база данных SQL Server 2000
является довольно сложной структурой. Более того, процесс создания базы
данных может представлять собой не только собственно создание новой базы,
но и присоединение готовых файлов данных. В Enterprise Manager не всегда
пользователи получают все возможные средства создания баз данных,
предлагаемые SQL Server 2000. Доступ к этим средствам обеспечивают только
команды Transact-SQL.
Этапу создания непосредственно предшествует фаза планирования, которая
включает в себя проектирование состава файлов и групп файлов, из которых
будет состоять база данных. Это планирование физической части.
Неотъемлемой частью процесса создания базы данных является и планирование
логической архитектуры, в которую входит проектирование таблиц с
использованием нормализации. Однако создание собственно базы данных не
требует предварительного проектирования таблиц.
Итак, начнем рассмотрение работы с базами данных с ее создания. В
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. Это ключевое слово означает, что далее следует описание
первичного файла базы данных. Напомним, что в этом файле хранятся все
системные данные и таблицы. Только один файл в базе данных может быть
определен как первичный. Если первичный файл не определен явно, то в этом
качестве будет использоваться первый файл, указанный в конструкции ,
синтаксис которой приведен ниже. Эта конструкция имеет одинаковый формат
для всех типов файлов (первичного, вторичного и журнала транзакций).
Чтобы соответствующий файл был первичным, перед его определением
необходимо указать ключевое слово PRIMARY. Журнал транзакций определяется
с помощью ключевого слова LOG ON. Если ни одно из этих ключевых слов не
указывается (указывается только слово ON), то соответствующий файл будет
вторичным. Дополнительно файлы данных могут быть включены в группы. Это
будет рассмотрено несколько позже в этом же разделе.
< filespec >
( [ NAME = Iogica1_file_name , ]
FILENAME = "os_file_name"
[ , SIZE = size ]
[ . MAXSIZE = { max_size | UNLIMITED } ]
[ . FILEGROWTH = growthj increment ] ) [ . ...n ]
Рассмотрим назначение используемых аргументов.
О NAME = logical_file_name. Логическое имя файла, под которым он будет
опознаваться при выполнении различных команд Transact-SQL. Логическое
имя файла должно быть уникальным в пределах базы данных. Имя файла
журнала транзакций не должно совпадать с именем файла самой базы
данных. Использование ключевого слова NAME не требуется, если
выполняется присоединение базы данных, однако таким образом можно
указать новое логическое имя для физического файла.
О FILENAME = "os_f 11 e_name". Если с помощью предыдущего аргумента
указывалось логическое имя файла, то рассматриваемый аргумент
предназначен для указания полного пути и названия соответствующего
физического файла, который будет создан на жестком диске. Это имя будет
иметь файл на уровне операционной системы. Если вы воспользуетесь какой-
либо программой просмотра диска, то после успешного выполнения команды
CREATE DATABASE сможете увидеть файл с указанным именем. Напомним, что
SQL Server 2000 не позволяет создавать файлы базы данных на сжатых
томах и сетевых дисках.
По умолчанию для файлов баз данных используются расширения .mdf, .ndf и
.Idf соответственно для первичного, вторичных файлов и файлов журнала
транзакций. В принципе, вы можете указать любое другое расширение, но
вряд ли найдется серьезная причина делать это. Чтобы не создавать
путаницы, советуем оставлять значения по умолчанию, то есть при описании
файла не указывать расширение.
О SIZE = size. С помощью этого аргумента указывается первоначальный
размер, который будет иметь соответствующий файл. Размер может быть
указан либо в мегабайтах, либо в килобайтах. Для явного задания величины
можно использовать приставки М b и К Ь. По умолчанию считается, что
размер задается в мегабайтах. Минимальный размер файла составляет 512
Кбайт. Если размер файла не указывается явно, то по умолчанию будет
создан файл размером
| | скачать работу |
SQL Server 2000 |