Структура баз данных в MS SQL Server
Рассмотрение способов создания и настройки базы данных, характеристика её структуры. Исследование вопросов сжатия баз данных, их резервного копирования и восстановления. Изменение владельца базы данных, её переименование. Способы сжатия базы данных.
Рубрика | Программирование, компьютеры и кибернетика |
Вид | лекция |
Язык | русский |
Дата добавления | 03.04.2019 |
Размер файла | 21,7 K |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Размещено на http://www.allbest.ru/
Лекция
Структура баз данных в MS SQL Server
В лекции рассматриваются способы создания и настройки БД, а также ее структура: первичные файлы, файловые группы, журнал. Затрагиваются вопросы сжатия БД и резервного копирования и восстановления.
Цель: познакомить со структурой базы данных в MS SQL Server 2008 и научить создавать базы данных и управлять ими.
Планирование физической организации базы данных - важнейшая часть административной работы с базами данных, файлами и файловыми группами. Плохо физически организованная будет работать с меньшей производительностью. резервное копирование восстановление база
Создание и настройка базы данных
СУБД MS SQL Server предлагает возможных вариантов создания базы данных:
1. Использование графического интерфейса Management Studio.
2. Использование команд SQL.
Создание базы данных - это процесс указания имени файла, определения размеров и размещения файлов базы данных, а также определение параметров файла журнала транзакций.
Можно выделить три типа файлов в базах данных MS SQL Server:
1. Первичные файлы данных. Как правило, используется расширение MDF. В любой базе данных есть один первичный файл, который содержит данные и расположение всех остальных файлов БД.
2. Вторичные файлы данных. Как правило, используется расширение NDF. Вторичным является любой файл кроме первичного и файлов журналов. БД могут не содержать ни одного вторичного файла.
3. Файлы журналов. Как правило, используется расширение LDF. В каждой БД существует по меньшей мере один файл журнала. Журнал транзакций содержит сведения об изменениях, происходящих в БД, т.е. при совершении некоторой транзакции (операции) в этот журнал заносятся сведения. Со временем этот журнал становится все больше, поэтому требуется следить за его размером. Основное назначение журнала транзакций - это обеспечение целостности данных. Он позволяет отменять сделанные изменения в БД.
Для удобства администрирования и распределения нагрузки файлы можно объединять в файловые группы, которые делятся на два вида.
1. Первичные файловые группы. Сюда входят первичный файл и все файлы, которые явным образом не были помещены в другую группу.
2. Пользовательские файловые группы - это любая группа создаваемая пользователем в БД.
Файлы журналов не входят ни в одну файловую группу, они обрабатываются отдельно от обычных файлов.
Новая база данных представляет собой копию базы данных model, все параметры которой копируются в новую базу данных. По умолчанию базы данных имеют создавать только те пользователи, которым назначены роли sysadmin и dbcreator.
Создание базы данных осуществляется с помощью команды:
CREATE DATABASE имя_базы_данных
[ON [PRIMARY] (NAME = 'логическое_имя_файла',
FILENAME = 'физическое_имя_файла'
[, SIZE = размер]
[, MAXSIXE = {максимальный_размер | UNLIMITED} ]
[, FILEGROWTH = шаг_приращения_размера [Mb | Kb | %] )
[ {FILEGROUP имя_файловой_группы} ]
[, ...n ]
[LOG ON (NAME = 'логическое_имя_файла',
FILENAME = 'физическое_имя_файла'
[, SIZE = размер]
[, MAXSIXE = {максимальный_размер | UNLIMITED} ]
[, FILEGROWTH = шаг_приращения_размера [Mb | Kb | %] )
[, ...n ]
Описание параметров:
· PRIMARY - определяет файл как первичный или как член первичной файловой группы, если опущено, то основным файлом становится первый файл в операторе и для хранения используется первичная файловая группа;
· NAME - определяет логическое имя файла. По умолчанию совпадает с физическим именем файла, определенном в параметре FILENAME;
· FILENAME - указывает полный путь и имя физического файла;
· SIZE - указывает размер файла: в мегабайтах, килобайтах. Минимально возможное значение 512 Кб. Размер основного файла по умолчанию равен размеру БД model. По умолчанию размер дополнительных файлов данных и журнала равен 1 Мб;
· MAXSIZE - указывает максимальный размер, до которого может увеличиваться файл. Если этот параметр не указан, то устанавливается значение UNLIMITED, позволяющее увеличивать файлам размер без ограничений;
· FILEGROWTH - задает шаг увеличения файла, причем ноль означает запрет увеличения размера. Значение указывается в мегабайтах, килобайтах или процентах. По умолчанию приращение - 10%, если не указаны единицы, то цифра воспринимается в мегабайтах;
· FILEGROUP - определяет имя группы файлов, в которую помещается файл.
Для просмотра информации о базе данных, файлах и группах файлов используются следующие хранимые процедуры:
· sp_helpdb [база_данных] - информация о базе данных и ее настройках. Если база данных не указана, то отображается отчет по всем базам данных, поддерживаемых данным MS SQL Server.
· sp_helpfile [`имя'] - информация о файлах, относящихся к текущей базе данных. Если имя файла не указано, то отображается информация обо всех файлах этой базы данных.
· sp_helpfilegroup [`имя'] - информация обо всех файловых группах в текущей базе данных. Если указано имя файловой группы, то выводится информация по каждому файлу указанной группы.
· sp_spaceused [`объект'] - сведения о дисковом пространстве, используемом указанным объектом.
Помимо перечисленных выше физических параметров база данных имеет еще и логические параметры. Только владелец и системный администратор может изменить эти параметры. Управление параметрами осуществляется с помощью системной хранимой процедуры sp_dboption:
sp_dboption [ [@dbname=] `имя_базы' ] [, [@option=] `']
[, [@value=] ON | OFF]
Изменение базы данных
Удаление базы данных осуществляется с помощью оператора:
DROP DATABASE имя_базы_данных [, …n]
В результате удаляются все файлы, используемые базой данных. Правом на удаление обладает владелец базы и пользователи роли sysadmin, это право не может быть передано другим учетным записям.
Изменение владельца базы данных производится с помощью специальной хранимой процедуры. Владельцем можно сделать любую учетную запись, которая в настоящий момент не является пользователем базы, следующим образом:
sp_changedbowner [ [@loginname=] `имя_пользователя'
Переименование базы данных:
sp_renamedb [@old_name=] `старое_имя', [@new_name=] `новое_имя'
Для переименования базы данных ее необходимо перевести в однопользовательский режим работы.
Для управления уже существующими файлами журнала и файлами данных, добавления дополнительных файлов данных или журнала, удаления файлов, а также для работы с файловыми группами используется команда:
ALTER DATABASE база_данных
{ ADD FILE <указание_на_файл> [TO FILEGROUP наименование]
| ADD LOG FILE <указание_на_файл>
| REMOVE FILE логическое_имя_файла
| ADD FILEGROUP имя_группы
| REMOVE FILEGROUP имя_группы
| MODIFY FILE <указание_на_файл>
| MODIFY FILEGROUP имя_группы свойство_группы }
где <указание_на_файл> =
(NAME = 'логическое_имя_файла',
FILENAME = 'физическое_имя_файла'
[, SIZE = размер]
[, MAXSIXE = {максимальный_размер | UNLIMITED} ]
[, FILEGROWTH = шаг_приращения_размера [Mb | Kb | %] )
Данная команда позволяет добавлять файл в существующую файловую группу, удалять файлы (при этом удаляется и физический файл), добавлять и удалять файловые группы, изменять физические параметры уже существующих файлов, а также изменять свойства файловых групп: READONLY, READWRITE, DEFAULT (при определении этого свойства, в эту группу будет заносится файлы, у которых в параметрах не определена принадлежность к группе; установленной по умолчанию изначально считается первичная файловая группа).
Сжатие базы данных
Сжатие базы данных - это процесс уменьшения размеров файлов базы данных за счет удаления неиспользуемых частей файла. Существует три способа сжатия базы данных:
· автоматическое сжатие при установке соответствующего параметра в настройках базы данных;
· удаление свободного пространства из файлов базы данных с помощью утилит администрирования MS SQL Server;
· уменьшение размера указанных файлов (или файловых групп), а также очистка содержимого файлов для их последующего удаления.
Автоматическое сжатие данных выполняется постоянно с определенными интервалами, если установлен параметр базы данных autoshrink. При операциях автоматического сжатия нельзя определить, какую часть базы данных необходимо сжать. MS SQL Server пытается освободить значительную часть базы данных самостоятельно. Эти операции выполняются в период наименьшей активности пользователей.
Сжатие всей базы данных вручную осуществляется с использованием следующей команды:
DBCC SHRINKDATABASE (`имя_БД', [`процент'] [, NOTRUNCATE | TRUNCATEONLY])
Описание параметров:
· имя_БД - имя базы данных, которую необходимо сжать;
· процент - количество процентов свободного пространства, которое желательно оставить после сжатия;
· NOTRUNCATE - сводное пространство не возвращается операционной системе, а резервируется в файлах, т.е. физически уменьшения размера базы данных не происходит;
· TRUNCATEONLY - свободное пространство удаляется за последним используемым в файле экстентом Экстент - непрерывная область памяти на накопителе., при этом данные не перемещаются, а параметр процент игнорируется.
Права на сжатие базы данных выданы только членам роли sysadmin и владельцам базы данных. После сжатия базы данных выводится отчет, в котором указывается:
· количество страниц, до которых сжимается файл;
· расчетное число страниц, в которые могут быть помещены все данные файла;
· количество страниц, содержащих данные;
· количество страниц, на которые файл может быть еще сжат.
Нельзя сжать базу данных до размера меньше первоначального.
Сжатие базы данных можно осуществить также и путем сжатия каждого ее файла с помощью следующей команды:
DBCC SHRINKFILE (`имя_файла', [`конечный_размер']
[, EMPTYFILE | NOTRUNCATE | TRUNCATEONLY ])
Описание параметров:
· имя_файла - логическое имя файла, который необходимо сжать;
· конечный_размер - желательный размер (целое число в мегабайтах), который должен иметь файл после выполнения сжатия. Если этот параметр не указан или меньше минимально допустимого размера, то файл сжимается до минимально возможного размера;
· EMPTYFILE - выполняется перенос данных из файла в другие файлы файловой группы;
· NOTRUNCATE - освободившееся место не возвращается операционной системе, т.е. размер файла не уменьшается на самом деле. При этом данные располагаются более компактно и смещаются к началу файла;
· TRUNCATEONLY - происходит обрезание файла, начиная с последней используемой страницы. Никакого перемещения данных не происходит.
Резервное копирование данных
Необходимо уделять особое внимание целостности информации, с которой работает пользователь. MS SQL Server предлагает следующие типы резервного копирования информации:
· полная копия базы данных, которая является отправной точкой при восстановлении базы данных после сбоя, однако в зависимости от объема данных этот процесс может занимать много времени, поэтому не рекомендуется выполнять его слишком часто. Полная копия содержит все данные, содержащиеся в базе данных на момент окончания резервирования;
· копия журнала транзакций, необходима для фиксирования всех изменений данных, произошедших в системе с момента последнего резервного копирования. Сама копия журнала содержит сведения о транзакциях и лишь только вместе с копией базы данных позволяет вернуться к состоянию, предшествующему сбою;
· дифференциальная копия данных содержит изменения данных, произошедшие с момента последнего создания полной копии базы данных. При этом сохраняются только страницы подвергшиеся изменениям. Таким образом, для восстановления базы данных достаточно самой последней дифференциальной копии.
Для выполнения резервного копирования необходимо выбрать носитель, т.е. определить устройство, которое будет использоваться для создания копий. Для добавления устройства используется хранимая процедура:
sp_addumpdevice `тип_устройства', `логическое_имя', `физическое_имя'
Описание параметров:
· тип_устройства - тип устройства резервного копирования. Допустимые значения: TAPE (магнитная лента), DISK (магнитный диск);
· логическое_имя, физическое_имя - логическое и физическое имя устройства резервного копирования соответственно.
Для создания резервной копии базы данных, журнала транзакций, файлов и файловых групп необходимо воспользоваться командой:
BACKUP {LOG | DATABASE } имя_БД
[ FILE = `логическое_имя_файла', ...]
[ FILEGROUP = `имя_группы' ]
TO логическое_имя_устройства
[ WITH
[ DESCRIPTION = `комментарий' ]
[ DIFFERENTIAL ]
[ EXPIREDATE = `дата' ]
[ INIT | NOINIT ] ... ]
Описание параметров:
· DIFFERENTIAL - создается дифференциальная копия базы данных;
· EXPIREDATE - определяется дата, после которой резервная копия считается устаревшей и может быть перезаписана;
· INIT | NOINIT - система осуществляет или нет инициализацию устройства.
Восстановление базы данных
При восстановлении базы данных из резервной копии существующая база данных будет перезаписана. Для восстановления базы данных используется команда:
RESTORE {LOG | DATABASE } имя_БД
`файл_или_файловая_ группа'
[ FROM логическое_имя_устройства ]
[ WITH
[ DBO_ONLY ]
[ MOVE `логическое_имя_файла' TO `физическое_имя' ] ... ]
Описание параметров:
· DBO_ONLY - разрешается доступ к восстановленной базе только владельцам;
· MOVE - указывает, какое физическое имя будет соответствовать восстанавливаемому файлу. По умолчанию файл восстанавливается с тем же физическим именем, которое было определено при резервном копировании.
Краткие итоги. Изучены основные физические элементы базы данных: первичные файлы, файловые группы, журнал. Продемонстрировано создание новой БД и управление ею. Показаны возможности резервного копирования и сжатия БД.
Размещено на Allbest.ru
...Подобные документы
Использование приложения "IBExpert" для создания, удаления, регистрации, подключения, извлечения метаданных, резервного копирования и восстановления базы данных СУБД Firebird. Основные SQL-операторы для создания, подключения и удаления базы данных.
лабораторная работа [280,1 K], добавлен 02.06.2015Типы изображений (черно-белые, полутоновые, цветные) и их форматы. Устройства, создающие цифровые изображения, и их параметры. Применение и характеристики методов сжатия изображений. Поиск по содержимому в базах данных изображений. Структуры баз данных.
презентация [360,4 K], добавлен 11.10.2013Создание таблиц базы данных с помощью MS Access "Страны Азии". Форма базы данных и запросы к выборкам данных. Модификация структуры таблиц, создания связей между главными таблицами, редактирование данных и проектирование форм для реальной базы данных.
контрольная работа [723,9 K], добавлен 25.11.2012Что такое базы данных, визуализация информации базы. Структура и свойства простейшей базы данных. Характеристика определений, типов данных, безопасность, специфика формирования баз данных. Подходы к проектированию технического задания. Работа с таблицами.
презентация [4,3 M], добавлен 12.11.2010Основные виды баз данных. Система управления базами данных. Анализ деятельности и информации, обрабатываемой в поликлинике. Состав таблиц в базе данных и их взаимосвязи. Методика наполнения базы данных информацией. Алгоритм создания базы данных.
курсовая работа [3,1 M], добавлен 17.12.2014Концептуальное проектирование базы данных: разработка схемы и структуры таблиц, описание атрибутов. Реализация базы данных в среде СУБД MS SQL Server 2000. Основные принципы создания таблиц. Доступ и обработка данных с помощью утилиты Enterprise Manager.
курсовая работа [3,8 M], добавлен 22.01.2013Разработка базы данных для информационной поддержки деятельности аптеки с целью автоматизированного ведения данных о лекарствах аптеки. Проектирование схемы базы данных с помощью средства разработки структуры базы данных Microsoft SQL Server 2008.
курсовая работа [3,6 M], добавлен 18.06.2012Понятие базы данных, модели данных. Классификация баз данных. Системы управления базами данных. Этапы, подходы к проектированию базы данных. Разработка базы данных, которая позволит автоматизировать ведение документации, необходимой для деятельности ДЮСШ.
курсовая работа [1,7 M], добавлен 04.06.2015Структура простейшей базы данных и свойства полей. Характеристика типов данных. Описание процесса создания базы данных, таблиц и связей между ними, простых и составных форм, запросов в Microsoft Access. Пример составления подчинённых отчетов и макросов.
курсовая работа [2,9 M], добавлен 14.11.2016Сущности и функциональные зависимости базы данных. Атрибуты и связи. Таблицы базы данных. Построение ER-диаграммы. Организация ввода и корректировки данных. Реляционная схема базы данных. Реализация запросов, получение отчетов. Защита базы данных.
курсовая работа [2,4 M], добавлен 06.02.2016Резервные базы данных под управлением Oracle Data Guard. Создание физической резервной базы. Защита резервных копий баз данных и базы данных разработчиков. Восстановление базы данных на удаленной машине. Стратегия резервирования и восстановления.
дипломная работа [499,7 K], добавлен 04.06.2013Понятия банка и базы данных, ее компоненты. Многоуровневые модели предметной области, их представление в базе данных. Идентификация объектов и записей. Способы обращения к записям или отдельным элементам данных, их поиск. Определение структуры данных.
контрольная работа [39,6 K], добавлен 10.04.2010Проектирование логической структуры базы данных методом нормальных форм, сущность связь. Сравнительный анализ спроектированной базы данных и базы данных существующих информационных систем. Выбор и обоснование состава технических и программных средств.
курсовая работа [3,0 M], добавлен 22.12.2014Содержание просопографической базы данных по высшему командному составу Советских вооруженных сил периода Великой Отечественной войны, структура реляционной базы данных. База данных по депутатам I Государственной Думы. Программное обеспечение баз данных.
реферат [11,6 K], добавлен 08.03.2010Создание таблиц и просмотр содержимого базы данных. Редактирование данных и модификация структуры базы данных. Методы упорядочения записей (сортировка, индексирование). Выполнение вычислений в запросах. Приемы работы с формами, отчетами и макросами.
лабораторная работа [5,9 M], добавлен 13.01.2010Основные сведения об SQL Server. Логическая структура реляционной базы данных. Создание базы данных Server. Обработка элементов оператора SELECT. Структура таблиц inserted и deleted. Ввод данных в таблицу "Клиенты". Краткая справка по языку запросов SQL.
курсовая работа [2,9 M], добавлен 11.05.2012Освоение сервисной системы управления базами данных Microsoft SQL. Разработка базы данных "Служба АТС" в среде Microsoft SQL Server Management Studio и создание запросов на языке SQL. Апробация инфологической модели "сущность - связь" базы данных.
курсовая работа [2,9 M], добавлен 29.06.2015Авторизация с каталогами проектирования базы данных магазина. Задачи базы данных: учет всех товаров, поиск и выдача данных о клиентах, адрес, телефоны, цена и наличие товара. Этапы проектирования базы данных. Схема данных, создание запросов и их формы.
реферат [1,6 M], добавлен 22.10.2009Разработка базы данных, содержащей информацию, необходимую Государственной инспекции по маломерным судам для выдачи билетов владельцам судов. Особенности создания файла и диаграмм базы данных, SQL-запросов. Объекты информационной модели и их свойства.
курсовая работа [1,3 M], добавлен 24.10.2012Составление схемы концептуальной модели данных. Разработка структуры реляционной базы данных и интерфейса пользователя. Особенности главных этапов проектирования базы данных. Способы реализации запросов и отчетов. Специфика руководства пользователя.
курсовая работа [186,9 K], добавлен 18.12.2010