Поделиться через


Как обновить базу данных при помощи отсоединения и присоединения (Transact-SQL)

Изменения: 5 декабря 2005 г.

ms189625.security(ru-ru,SQL.90).gifПримечание безопасности.
Не рекомендуется присоединять или восстанавливать базы данных, полученные из неизвестных или ненадежных источников. В этих базах данных может содержаться вредоносный код, вызывающий выполнение непредусмотренных инструкций Transact-SQL или появление ошибок из-за изменения схемы или физической структуры базы данных. Перед тем как использовать базу данных, полученную из ненадежного источника, выполните инструкцию DBCC CHECKDB для этой базы данных на непроизводственном сервере, а также изучите исходный код в базе данных, например хранимые процедуры и другой пользовательский код.

В SQL Server 2005 можно отсоединить и присоединить для обновления пользовательской базы данных из SQL Server версии 7.0 или SQL Server 2000. Однако действуют следующие ограничения:

  • резервные копии баз данных master, model или msdb, созданные с помощью SQL Server 7.0 или SQL Server 2000, невозможно присоединить в SQL Server 2005;
  • файлы журналов SQL Server 7.0, содержащие операции создания индекса, невозможно присоединить в SQL Server 2000 и SQL Server 2005.
ms189625.note(ru-ru,SQL.90).gifВажно!
Резервные копии баз данных, созданные с помощью SQL Server 6.5 или более ранних версий, имеют несовместимый формат, поэтому их нельзя присоединить к SQL Server 2005.
  • присоединение скопированной, а не отсоединенной реплицируемой базы данных:
    • если база данных присоединяется к обновленной версии того же экземпляра сервера, необходимо обновить репликацию после завершения присоединения с помощью хранимой процедуры sp_vupgrade_replication. Дополнительные сведения см. в разделе sp_vupgrade_replication (Transact-SQL);
    • если база данных присоединяется к другому экземпляру сервера (независимо от версии), необходимо удалить репликацию после завершения присоединения с помощью хранимой процедуры sp_removedbreplication. Дополнительные сведения см. в разделе Хранимая процедура sp_removedbreplication (Transact-SQL).

При использовании ключевых слов APPLY, PIVOT, TABLESAMPLE или UNPIVOT в базах данных, обновленных до версии SQL Server 2005, база данных должна иметь уровень совместимости 90. Сведения о настройке уровня совместимости базы данных см. в разделе sp_dbcmptlevel (Transact-SQL).

ms189625.note(ru-ru,SQL.90).gifВажно!
В SQL Server 2000 с пакетом обновления 3 (SP3) и более поздних версиях SQL Server присоединение и отсоединение отменяют межбазовые цепочки владения для базы данных, присваивая параметру cross db ownership chaining значение 0. Сведения о включении цепочек владения см. в разделе Параметр cross db ownership chaining.

Процедуры

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

  1. Отсоедините базу данных от экземпляра сервера SQL Server 7.0 или SQL Server 2000 с помощью хранимой процедуры sp_detach_db.

    Дополнительные сведения см. в электронной документации по SQL Server для этой версии SQL Server.

    ms189625.note(ru-ru,SQL.90).gifПримечание.
    В SQL Server 2005 у этой хранимой процедуры есть новые параметры. Дополнительные сведения см. в разделе sp_detach_db (Transact-SQL).
  2. При необходимости переместите отсоединенные файлы баз данных и файлы журналов.

    Файлы журнала и файлы данных следует переместить, даже если планируется создать новые файлы журнала. В некоторых случаях для повторного присоединения базы данных требуются файлы ее существующих журналов. Поэтому всегда храните все файлы отсоединенных журналов, пока база данных не будет успешно присоединена без них.

    ms189625.note(ru-ru,SQL.90).gifПримечание.
    При попытке присоединить базу данных, не указывая файл журнала, операцией присоединения будет произведен поиск файла журнала в его исходном месте. Если первоначальная копия журнала существует в этом расположении, она будет присоединена. Чтобы избежать применения исходного файла журнала, либо укажите путь к новому файлу журнала либо удалите исходную его копию (после его копирования в новое место).
  3. Присоедините скопированные файлы к экземпляру сервера SQL Server 2005 с помощью инструкции CREATE DATABASE с параметром FOR ATTACH или FOR ATTACH_REBUILD_LOG.

    ms189625.note(ru-ru,SQL.90).gifПримечание.
    Дополнительные сведения о присоединении базы данных SQL Server 2005 с помощью обозревателя объектов см. в разделе Как присоединить базу данных (среда Microsoft SQL Server Management Studio).
  4. В обновленной базе данных рекомендуется запуск инструкции DBCC UPDATEUSAGE.

    В более ранних версиях SQL Server значения количества строк таблиц и индексов, а также количества страниц могут стать неправильными. Поэтому базы данных, созданные с помощью версий до SQL Server 2005, могут содержать неверные подсчеты. После обновления базы данных до версии SQL Server 2005 рекомендуется запустить инструкцию DBCC UPDATEUSAGE для исправления любых неверных показаний счетчиков. Инструкция DBCC исправляет счетчики строк таблицы, использованных страниц, зарезервированных страниц, конечных страниц и страниц данных для каждого раздела таблицы или индекса. Дополнительные сведения см. в разделе DBCC UPDATEUSAGE (Transact-SQL).

  5. При копировании базы данных (вместо перемещения) можно при необходимости заново присоединить оригинал базы данных к экземпляру SQL Server 7.0 или SQL Server 2000 с помощью хранимой процедуры sp_attach_db или sp_attach_single_file_db.

    Дополнительные сведения см. в электронной документации по SQL Server для этой версии SQL Server.

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

Чтобы обеспечить согласованное функционирование базы данных для пользователей и приложений, когда она присоединяется к другому экземпляру сервера, на другом экземпляре сервера, возможно, понадобится повторно создать некоторые или все метаданные базы данных, например имена входа, задания и разрешения. Дополнительные сведения см. в разделе Управление метаданными при обеспечении доступности базы данных на другом экземпляре сервера.

Примеры

В следующем примере обновляется база данных SQL Server 2000 pubs до базы данных SQL Server 2005 с помощью инструкций Transact-SQL для отсоединения и присоединения базы данных.

  1. Присоедините программу Query Analyzer SQL Server 2000 к экземпляру сервера, к которому присоединена база данных pubs, и отсоедините базу данных с помощью хранимой процедуры sp_detach_db.

    USE master;
    GO
    EXEC sp_detach_db @dbname = N'pubs';
    GO
    
  2. В данном примере скопируйте любым способом файлы базы данных pubs (pubs.mdf и pubs_log.ldf) из «C:\Program Files\Microsoft SQL Server\MSSQL\Data\» (это расположение по умолчанию для базы данных pubs в SQL Server 2000) в местоположение «C:\Program Files\Microsoft SQL Server\MSSQL.1\MSSQL\Data\» (это каталог данных SQL Server 2005).

    ms189625.note(ru-ru,SQL.90).gifВажно!
    При работе с производственными базами данных помещайте базу данных и журналы транзакций на отдельные диски.
    ms189625.note(ru-ru,SQL.90).gifПримечание.
    Чтобы скопировать файлы через сеть на диск удаленного компьютера с помощью имени удаленной точки, соответствующего формату UNC. Имя, соответствующее UNC, имеет следующий формат: \\Имя_сервера\Имя_ресурса\Путь\Имя_файла. Как и при записи файлов на локальный жесткий диск, учетной записи пользователя SQL Server должны быть предоставлены разрешения на чтение или запись в файл на удаленном диске.
  3. Присоедините скопированную базу данных pubs и (при необходимости) файлы журнала в экземпляр SQL Server 2005 (в этом примере используется имя той же базы данных). В среде SQL Server Management Studio откройте новый запрос редактора запросов и соединитесь с экземпляром сервера, к которому нужно присоединить базу данных.

    ms189625.note(ru-ru,SQL.90).gifПримечание.
    Дополнительные сведения см. в разделе Запрос на языке Transact-SQL в среде SQL Server Management Studio.

    Выполните следующую инструкцию CREATE DATABASE.

    USE master;
    GO
    CREATE DATABASE pubs ON PRIMARY 
       (FILENAME = 
          'C:\Program Files\Microsoft SQL Server\MSSQL.1\MSSQL\Data\pubs.mdf')
       LOG ON (FILENAME = 
          'C:\Program Files\Microsoft SQL Server\MSSQL.1\MSSQL\Data\pubs_log.ldf')
       FOR ATTACH;
    GO
    
    ms189625.note(ru-ru,SQL.90).gifПримечание.
    В среде SQL Server Management Studio только что присоединенная база данных отображается в обозревателе объектов не сразу. Для просмотра базы данных щелкните окно обозревателя объектов и выберите Просмотр > Обновить. Когда узел баз данных развернут, только что присоединенная база данных появится в списке баз данных.
  4. При необходимости присоедините оригинал базы данных pubs к экземпляру SQL Server 2000 с помощью хранимой процедуры sp_attach_db. В программе Query Analyzer введите следующее:

    USE master;
    Go
    EXEC sp_attach_db @dbname = N'pubs', 
       @filename1 = 
          N'c:\Program Files\Microsoft SQL Server\MSSQL\Data\pubs.mdf', 
       @filename2 = 
          N'c:\Program Files\Microsoft SQL Server\MSSQL\Data\pubs_log.ldf';
    GO
    

См. также

Задачи

Как присоединить базу данных (среда Microsoft SQL Server Management Studio)
Как выполнить обновление до версии SQL Server 2005 с помощью мастера копирования баз данных

Основные понятия

Присоединение и отсоединение баз данных
Защита данных и файлов журналов

Другие ресурсы

CREATE DATABASE (Transact-SQL)
Использование помощника по обновлению для подготовки к обновлениям

Справка и поддержка

Получение помощи по SQL Server 2005