МЕНЮ


Фестивали и конкурсы
Семинары
Издания
О МОДНТ
Приглашения
Поздравляем

НАУЧНЫЕ РАБОТЫ


  • Инновационный менеджмент
  • Инвестиции
  • ИГП
  • Земельное право
  • Журналистика
  • Жилищное право
  • Радиоэлектроника
  • Психология
  • Программирование и комп-ры
  • Предпринимательство
  • Право
  • Политология
  • Полиграфия
  • Педагогика
  • Оккультизм и уфология
  • Начертательная геометрия
  • Бухучет управленчучет
  • Биология
  • Бизнес-план
  • Безопасность жизнедеятельности
  • Банковское дело
  • АХД экпред финансы предприятий
  • Аудит
  • Ветеринария
  • Валютные отношения
  • Бухгалтерский учет и аудит
  • Ботаника и сельское хозяйство
  • Биржевое дело
  • Банковское дело
  • Астрономия
  • Архитектура
  • Арбитражный процесс
  • Безопасность жизнедеятельности
  • Административное право
  • Авиация и космонавтика
  • Кулинария
  • Наука и техника
  • Криминология
  • Криминалистика
  • Косметология
  • Коммуникации и связь
  • Кибернетика
  • Исторические личности
  • Информатика
  • Инвестиции
  • по Зоология
  • Журналистика
  • Карта сайта
  • SQL Server 2000

    нередко требуется выполнить и обратный процесс — уменьшение размера базы

    данных. Действительно, если из базы данных удаляется значительная часть

    данных или после нескольких дней напряженной работы пользователи

    существенно снижают нагрузку на сервер и в журнале транзакций образуется

    много свободного пространства, часто возникает необходимость вернуть

    неиспользуемое дисковое пространство в операционную систему. Как и

    увеличение базы данных, процесс уменьшения размера базы данных,

    называемый также сжатием базы данных (shrinking database), представляет

    собой уменьшение размера отдельных файлов, из которых состоит база

    данных.

    Операции сжатия базы данных по возможности должны выполняться в

    период наименьшей активности пользователей, чтобы доставлять им как можно

    меньше неудобств.

    Как и увеличение, сжатие базы данных может выполняться автоматически.

    Однако при автоматическом сжатии нет возможности контролировать размер,

    на который необходимо уменьшить размер файлов базы данных. Сервер

    пытается освободить как можно большую, но не всю свободную часть базы

    данных. То есть в некоторых случаях сервер может оставить в файле лишнее

    свободное пространство, тогда как в других свести его к минимуму. Такое

    неконтролируемое сведение к минимуму свободного пространства очень скоро

    приводит к необходимости нового увеличения размера файла. Конечно,

    разумнее было бы оставить в файле какой-то процент свободного

    пространства, но, к сожалению, сервер этого не делает.

    Автоматическое уменьшение размера базы данных происходит в том случае,

    когда сервер обнаруживает в базе данных слишком много неиспользуемого

    пространства.

    Несмотря на некоторые недостатки автоматического уменьшения размера

    базы данных, нельзя не отметить и неоспоримое преимущество —

    администратор освобождается от необходимости следить за размером базы

    данных, а также за объемом используемого и свободного пространства,

    переложив эту обязанность на сервер.

    Для разрешения или запрещения автоматического уменьшения базы данных

    используется хранимая процедура sp_dboption:

    sp_dboption "database_name", "autoshrink". ("true" | "false")

    С помощью первого аргумента указывается имя базы данных, свойства

    которой предполагается изменять. Второй аргумент должен оставаться таким,

    как он приведен выше. Указывая значение "true" или " f al se", можно

    соответственно разрешать и запрещать автоматическое уменьшение файлов

    базы данных.

    Автоматическое уменьшение размера базы данных можно разрешить и с помощью

    команды ALTER DATABASE, воспользовавшись аргументом SET. Более подробно

    управление свойствами базы данных будет рассмотрено в следующем разделе.

    Помимо автоматического можно также выполнять ручное уменьшение размера

    базы данных. Это делается с помощью команды контроля согласованности (или

    целостности) базы данных (database consistency check, DBCC):

    DBCC SHRINKDATABASE

    ( databasejname [ , target_percent ]

    [ , TRUNCATEONLY ]

    )

    Рассмотрим назначение аргументов.

    О database_name. Имя базы данных, которую необходимо сжать.

    О target_percent. Количество процентов свободного пространства, которое

    желательно оставить в базе данных после выполнения ее сжатия. Говоря

    точнее, с помощью рассматриваемого аргумента указывается процент от

    общего объема файлов базы данных, который должен быть незаполненным.

    Например, если в файле размером 10 Мбайт имеется 4 Мбайта свободного

    пространства, то для уменьшения количества неиспользуемого пространства

    до 2 Мбайт необходимо указать значение аргумента target_percent равным

    25. Сначала сервер вычисляет объем свободного и занятого пространства

    (соответственно 4 и 6 Мбайт). Чтобы получить искомые 25 процентов,

    соотношение свободного и занятого пространства должно быть 3 к 1. Путем

    нехитрых вычислений сервер приходит к выводу, что нужный результат

    будет получен при размере файла, равном 8 Мбайт. После этого сервер

    переносит все данные из последних 2 Мбайт файла в первые 8 Мбайт,

    помещая их в любое незанятое место на странице. После того как все

    данные будут перенесены, выполняется уменьшение размера файла. Заметим,

    что в аргументе target_percent нельзя указывать размер, превышающий

    текущий процент свободного пространства. В противном случае уменьшение

    размера файла выполнено не будет. Таким образом, выполняя команду DBCC

    SHRINKDATABASE

    г со слишком большим значением аргумента target_percent, можно получить

    ситуацию, когда уменьшения размера базы данных вообще не происходит.

    О NOTRUNCATE. При задании этого аргумента свободное пространство не

    возвращается операционной системе, а резервируется в файлах для

    будущего использования, то есть физически уменьшения размера базы

    данных не происходит. Тем не менее, сервер все же выполняет перенос

    данных в начало файла, как это было описано для предыдущего аргумента.

    О TRUNCATEONLY. При задании этого аргумента сервер удаляет все свободное

    пространство в файле за последним используемым экстентом. Значение

    аргумента target_percent при этом игнорируется. Не предпринимается

    никакой попытки перемещения данных для более эффективного их

    распределения в файле. Если в файле размером 2 Мбайт выделено всего два

    экстента в начале и в середине файла, то при использовании команды DBCC

    SHRINKDATABASE будет освобождена только половина файла, начиная от

    второго экстента и до конца файла. Размер файла будет составлять около

    1 Мбайт, хотя в принципе он мог быть уменьшен до 128 Кбайт.

    Права на сжатие базы данных с помощью команды DBCC SHRINKDATABASE выданы

    только членам фиксированной роли сервера sysadmin и фиксированной роли

    базы данных dbowner. Эти права не могут быть переданы пользователю

    никаким другим способом, кроме как включением его в одну из этих ролей.

    Чтобы уменьшить количество свободного пространства в базе данных pubs до

    15% с резервированием освобожденного пространства для дальнейшего

    использования, необходимо выполнить следующую команду: DBCC

    SHRINKDATABASE (pubs. 15. NOTRUNCATE)

    He имеет значения, в контексте какой базы данных выполняется команда DBCC

    SHRINKDATABASE, так как при ее вызове явно указывается имя нужной базы

    данных.

    После выполнения команды сервер выдаст примерно следующее сообщение:

    Dbld Fileld CurrentSize MinSize UsedPages EstimatedPages

    5 2 96 63 96 56

    (1 row(s) affected)

    DBCC execution completed. If DBCC printed error messages, contact your

    system

    administrator.

    Рассмотрим назначение столбцов в полученном результате. О Dbld —

    идентификационный номер базы данных. Этот номер-будет одинаков

    для всех отображаемых строк.

    О Fileld— идентификационный номер файла базы данных, размер которого был

    уменьшен в процессе сжатия базы данных. Если некоторые файлы не были

    сжаты, то информация о них не выводится.

    О CurrentSize— количество страниц, которое имеется в файле, причем

    учитываются как заполненные, так и свободные страницы.

    О MinimumSize— минимальное количество страниц, до которого может быть

    уменьшен файл. Это значение может ограничиваться начальным размером

    файла, установленным при его создании. В ином случае оно равно значению

    в столбце EstimatedPages.

    О UsedPages— количество страниц, содержащих данные.

    О EstimatedPages— количество страниц, до которого может быть сжат файл.

    Однако не всегда файл может быть сжат до указанного размера, так как

    нельзя установить размер файла меньше первоначального.

    Список баз данных и соответствующих идентификационных номеров хранится в

    таблице sysdatabases системной базы данных master. Для получения

    идентификационного номера базы данных можно использовать команду DB_ID

    ("databasename"). Если же необходимо определить имя базы данных по

    идентификационному номеру, то можно воспользоваться командой

    DB_NAME(database_id).

    Команда DBCC SHRINKDATABASE работает с целой базой данных. Если же

    необходимо уменьшить размер конкретного файла базы данных, то для этого

    следует использовать команду DBCC SHRINKFILE, имеющую следующий

    синтаксис:

    DBCC SHRINKFILE

    ( fllejd

    { [ . target_size ]

    j [ . TRUNCATEONLY ]

    Выполнение этой команды, в отличие от команды DBCC SHRINKDATABASE,

    должно производиться в контексте той базы данных, файл которой

    предполагается уменьшить. Напомним, что для переключения баз данных

    используется команда USE. Рассмотрим назначение аргументов команды DBCC

    SHRINKFILE. О f i 1 e_name | f i 1 e_i d. Имя файла, который необходимо

    сжать, или его иден-

    тификационный номер. Для получения идентификационного номера файла

    базы данных можно использовать команду FILE_ID: FILE ID ("filename")

    ПРИМЕЧАНИЕ

    Список файлов базы данных, их идентификационных номеров, логических и

    физических имен хранится в таблице sysfiles каждой базы данных.

    О target_size. Желательный размер (целое число в мегабайтах), который

    должен иметь файл после выполнения сжатия. Если размер не указывается,

    то файл сжимается до минимально возможного размера. При выполнении

    команды DBCC SHRINKFILE сервер при необходимости выполняет перемещение

    данных из части файла, которая должны быть удалена, в ту часть, которая

    будет оставлена. Если размер target_size меньше, чем минимально

    возможный размер файла, то сжатие файла будет выполняться только до

    минимально возможного размера. Например, если файл размером 20 Мбайт

    содержит 14 Мбайт данных, а пользователь пытается сжать его до 10

    Мбайт, то файл будет сжат только до 14 Мбайт. Если размер файла после

    сжатия становится

    меньше первоначального размера, то новый размер становится минимальным

    размером файла.

    О EMPTYFILE. При использовании этого аргумента сервер выполняет перенос

    данных из файла в другие файлы, включенные в ту же группу, что и

    сжимаемый файл. Сервер не будет добавлять новые данные в файл, сжатый с

    аргументом EMPTYFILE. Такой файл может быть уничтожен с помощью команды

    ALTER DATABASE REMOVE FILE.

    О NOTRUNCATE. Использование этого аргумента предписывает серверу не

    возвращать освободившееся место операционной системе. Таким образом,

    размер файла на самом деле не уменьшается. Данные в файле располагаются

    более компактно и смещаются к началу файла. Если аргумент NOTRUNCATE не

    указан, то освободившееся пространство возвращается операционной

    системе, то есть размер файла уменьшается.

    О TRUNCATEONLY. При указании этого аргумента сервер выполняет урезание

    части файла, начиная от последней используемой страницы до конца файла.

    Значение аргумента target_size в этом случае игнорируется. Никакого

    перемещения данных для более компактного их расположения не

    предпринимается. Для сжатия файла данных базы данных pubs до 1 Мбайт

    введите следующую команду:

    USE Pubs

    DBCC SHRINKFILE (pubs, 1)

    В результате сервер выдаст таблицу, подобную той, которая выдается при

    выполнении команды DBCC SHRINKDATABASE. Состав и назначение столбцов в

    обоих случаях аналогичны:

    Dbld Fileld CurrentSize MinimumSize UsedPages

    EstimatedPages

    5 1 296 80 288

    288

    (1 row(s) affected)

    DBCC execution completed. If DBCC printed error messages, contact your

    system

    administrator.

    Удостоверимся, что файлом с идентификационным номером 1 является файл

    pubs:

    SELECT FILE_ID("pubs") SELECT FILE_NAME(1)

    В итоге будет получен следующий результат:

    1

    (1 row(s) affected)

    pubs

    (1 row(s) affected)

    Права на выполнение команды DBCC SHRINKFILE выдаются таким же образом,

    как и для команды DBCC SHRINKDATABASE.

    Для журнала транзакций или его файлов сжатие происходит не сразу, а при

    последующем выполнении операции усечения (truncate) или резервного

    копирования.

    Управление свойствами базы данных

    Помимо перечисленных выше физических параметров (описывающих в основном

    имена, размеры, положение и другие характеристики файлов) база данных

    имеет еще и логические параметры. К этим параметрам относятся выполнение

    автоматического усечения журнала транзакций, автоматическое создание и

    обновление статистики, возможность выполнения вложенных триггеров и

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

    их разрешению или запрещению и осуществляется с помощью системной хранимой

    процедуры sp_dboption. Назначение основной части параметров было

    рассмотрено в главе 11. Синтаксис хранимой процедуры sp_dboption

    следующий:

    sp_dboption [[@dbname =] "database"] [. [@optname =] "optionjiame"] [.

    [@optva"lue =] "value"]

    Аргумент "database" содержит имя базы данных, в которой необходимо

    выполнить изменение конфигурации. Аргумент "value" определяет значение

    параметра. Возможны два варианта: значение ON или TRUE (параметра задан) и

    значение OFF или FALSE (параметра не задан). Аргумент "option_name"

    определяет имя параметра, который необходимо изменить. Возможные значения

    этого аргумента приведены в табл. с кратким указанием назначения каждого

    параметра.

    Таблица. Параметры конфигурации базы данных

    Параметр

    Назначение'

    a uto create statistics auto update statistics autoclose autoshrink ANSI

    null default ANSI nulls ANSI warning concat null yields null

    cursor close on commit

    dbo use only

    default to local cursor

    merge publish

    offline

    published

    quoted identifier

    read only recursive triggers select into/bulk copy

    Автоматическое создание статистики

    Автоматическое обновление статистики

    Автоматическое закрытие базы данных

    Автоматическое сжатие базы данных

    Разрешение значения 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

    . Как нетрудно догадаться, свойства базы данных, которые

    предполагается изменить, указываются с помощью конструкции ,

    имеющей следующий синтаксис:

    ::=

    < state_option >

    [ < cursor_option >

    | < auto_option >

    | < sql_option >

    | < recovery_option >

    < state_option > .- .- =

    RESTRICTED_USER

    | OFFLINE

    | READJ3NLY

    < termination >

    ROLLBACK AFTER integer [ SECONDS ]

    | ROLLBACK IMMEDIATE

    | NO WAIT

    < cursor_option > : : =

    CURSOR_CLOSE_ON_COMMIT ON

    | (CURSOR_DEFAULT GLOBAL

    < auto_option >

    AUTO_CLOSE ON

    | OFF

    | OFF

    | AUTO_UPDATE_STATISTICS ON

    < sql_option > ::=

    ANSI_NULL_DEFAULT OFF

    | ANSI_NULLS OFF

    j ANSI_PADDING OFF

    j ANSIJIARNINGS OFF

    | ARITHABORT ON

    | CONCAT_NULL_YIELDS_NULL ON

    | NUMERIC_ROUNDABORT OFF

    | QUOTEDJDENTIFIER { ON J OFF }

    | RECURSIVEJRIGGERS OFF

    < recovery_option > ::=

    RECOVERY BULK_LOGGED

    | TORN_PAGE_DETECTION OFF

    Практически все перечисленные аргументы были рассмотрены либо в этой главе,

    либо в главе 11. Поэтому мы не будет лишний раз на них останавливаться.

    Присоединение и отсоединение базы данных

    SQL Server 2000 позволяет отсоединять (detach) базы данных от сервера.

    Пользователи не могут обращаться к отсоединенным базам данных. Описание

    отсоединенной базы данных, включая описание файлов журнала транзакций и

    самой базы данных, удаляется из системных таблиц SQL Server и, таким

    образом, сервер перестает ее воспринимать. Позже эту базу данных можно

    присоединить (attach) на этом же или другом сервере.

    Отсоединение и присоединение в основном используются для переноса баз

    Страницы: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14


    Приглашения

    09.12.2013 - 16.12.2013

    Международный конкурс хореографического искусства в рамках Международного фестиваля искусств «РОЖДЕСТВЕНСКАЯ АНДОРРА»

    09.12.2013 - 16.12.2013

    Международный конкурс хорового искусства в АНДОРРЕ «РОЖДЕСТВЕНСКАЯ АНДОРРА»




    Copyright © 2012 г.
    При использовании материалов - ссылка на сайт обязательна.