Удаление приложения уровня данных
Для удаления приложения уровня данных (DAC) используйте мастер удаления приложения уровня данных или скрипт Windows PowerShell. Можно указать, будет ли связанная база данных сохранена, отсоединена или уничтожена.
Перед началом работы выполните следующие действия. Ограничения, Разрешения
Обновление приложения уровня данных с использованием следующих средств: Мастер регистрации приложения уровня данных, PowerShell
Перед началом работы
При удалении экземпляра приложения уровня данных (DAC) можно выбрать один из трех параметров, которые определяют действие над базой данных, связанной с этим приложением уровня данных. При использовании любого из трех параметров удаляются метаданные определения DAC. Различие между ними состоит в действиях, которые они выполняют с базой данных, связанной с приложением уровня данных. Мастер не удаляет ни один из объектов уровня экземпляра, связанных с DAC или базой данных, таких как имена входа.
Параметр |
Операции базы данных |
---|---|
Регистрация удаления |
Связанная база данных остается неизменной. |
Отсоединение базы данных |
Выполняется отсоединение связанной базы данных. Экземпляр компонента Database Engine не может ссылаться на эту базу данных, но данные и файлы журналов сохраняются целыми. |
Удаление базы данных |
Связанная база данных уничтожается. Происходит удаление данных и файлов журналов. |
[В начало]
Ограничения
Автоматический механизм восстановления метаданных определения приложения уровня данных или базы данных после удаления приложения уровня данных отсутствует. Способ, как можно будет вручную перестроить экземпляр приложения уровня данных, зависит от параметра удаления.
Параметр |
Повторное создание экземпляра приложения уровня данных |
---|---|
Регистрация удаления |
Зарегистрируйте приложение уровня данных из оставшейся базы данных. |
Отсоединение базы данных |
Повторно присоедините базу данных с помощью команды sp_attachdb или среды Среда SQL Server Management Studio и затем зарегистрируйте новый экземпляр приложения уровня данных из базы данных. |
Удаление базы данных |
Восстановите базу данных из полной резервной копии, созданной до удаления приложения уровня данных, а затем зарегистрируйте новый экземпляр приложения уровня данных из базы данных. |
Внимание! |
---|
При повторном создании экземпляра приложения уровня данных путем его регистрации из восстановленной или повторно присоединенной базы данных некоторые части исходного приложения уровня данных, например политика выбора сервера, не создаются повторно. |
[В начало]
Разрешения
Приложение уровня данных (DAC) может быть удалено только членами предопределенных ролей сервера sysadmin и serveradmin или владельцем базы данных. Этот мастер также может быть запущен от имени учетной записи системного администратора SQL Server с именем sa.
[В начало]
Использование мастера удаления приложения уровня данных
Удаление приложения уровня данных с помощью мастера
В Обозревателе объектов разверните узел экземпляра, содержащего приложение уровня данных, которое требуется удалить.
Разверните узел Управление.
Разверните узел Приложения уровня данных.
Щелкните правой кнопкой мыши приложение уровня данных, которое требуется удалить, и выберите пункт Удалить приложение уровня данных....
Выполните шаги в диалоговых окнах мастера.
Введение
Выбор метода
Сводка
Удалить приложение уровня данных
[В начало]
Вводная страница
На этой странице описаны шаги удаления приложения уровня данных.
Больше не показывать эту страницу. — щелкните этот флажок, чтобы предотвратить отображение этой страницы в будущем.
Далее> — переход к странице Выбор метода.
Отмена — отмена действий мастера без удаления приложения уровня данных или базы данных.
[Мастер удаления]
Страница «Выбор метода»
Используйте данную страницу, чтобы указать параметр для обработки связанной с удаляемым приложением уровня данных базы данных.
Регистрация удаления удаляет метаданные, определяющие приложение уровня данных, но оставляет неизменной связанную базу данных.
Отсоединение базы данных — удаляет метаданные, определяющие приложение уровня данных, и отсоединяет связанную базу данных.
На эту базу данных больше нельзя будет ссылаться из экземпляра компонента Компонент Database Engine, но данные и файлы журнала останутся неизменными.
Удаление базы данных — производится удаление метаданных, определяющих DAC, и уничтожение связанной базы данных.
Удаление данных и файлов журналов, относящихся к базе данных, осуществляется на постоянной основе.
< Назад — возврат к странице Введение.
Далее > — переход на страницу Сводка.
Отмена — завершение работы мастера без удаления DAC или базы данных.
[Мастер удаления]
Страница «Сводка»
На этой странице можно просмотреть действия, которые будут выполнены мастером при удалении экземпляра приложения уровня данных.
Просмотр сводки по своему выбору — предоставляет возможность ознакомиться со сведениями о DAC, базе данных и методе удаления, отображенными в этом окне. Если эти сведения правильны, выберите Далее или Готово, чтобы удалить DAC. Если сведения о DAC и базе данных неверны, выберите Отмена и правильно укажите DAC. Если неверным является метод удаления, нажмите кнопку Назад, чтобы вернуться к странице Выбор метода, и укажите другой метод.
< Назад — возврат к странице Выбор метода для выбора другого метода удаления.
Далее > — удаление экземпляра приложения уровня данных методом, выбранным на предыдущей странице, и переход к странице Удаление приложения уровня данных.
Отмена — завершение работы мастера без удаления экземпляра приложения уровня данных или базы данных.
[Мастер удаления]
Страница «Удаление приложения уровня данных»
Эта страница сообщает об успешном или неуспешном завершении операции удаления.
Удаление приложения уровня данных — сообщает об успехе или неуспехе каждого действия, предпринятого для удаления экземпляра приложения уровня данных. Просмотрите эти сведения, чтобы выяснить результаты каждого действия. Для каждого действия, в котором обнаружена ошибка, предусмотрена ссылка в столбце Результат. Выберите эту ссылку, чтобы просмотреть отчет об ошибках, относящихся данному действию.
Сохранить отчет — сохранить отчет об удалении в HTML-файле. В этом файле содержится отчет о состоянии каждого из действий, в том числе все выданные сообщения об ошибках. По умолчанию используется папка «SQL Server Management Studio\DAC Packages», вложенная в папку Documents рабочего каталога учетной записи пользователя Windows.
Готово — завершение работы мастера.
[Мастер удаления]
Удаление приложения уровня данных с помощью PowerShell
Удаление приложения уровня данных с помощью скрипта PowerShell
Создайте объект SMO Server и задайте его экземпляру, содержащему приложение уровня данных, которое требуется удалить.
Откройте объект ServerConnection и соединитесь с тем же экземпляром.
Используйте add_DacActionStarted и add_DacActionFinished для подписки на обновление событий приложения уровня данных.
Укажите приложение уровня данных, которое требуется удалить.
Используйте один из этих трех наборов кода в зависимости от того, какой из вариантов удаления является подходящим:
Для удаления регистрации приложения уровня данных без изменения базы данных используйте метод Unmanage().
Для удаления регистрации приложения уровня данных и отсоединения базы данных используйте метод Uninstall() и укажите DetachDatabase.
Для удаления регистрации приложения уровня данных и сброса базы данных используйте метод Uninstall() и укажите DropDatabase.
[В начало]
Пример удаления приложения уровня данных без изменения базы данных (PowerShell)
В следующем примере рассматривается удаление приложения уровня данных с названием MyApplication при помощи метода Unmanage(), который позволяет удалить приложение уровня данных без изменения базы данных.
## Set a SMO Server object to the default instance on the local computer.
CD SQLSERVER:\SQL\localhost\DEFAULT
$srv = get-item .
## Open a Common.ServerConnection to the same instance.
$serverconnection = New-Object Microsoft.SqlServer.Management.Common.ServerConnection($srv.ConnectionContext.SqlConnectionObject)
$serverconnection.Connect()
$dacstore = New-Object Microsoft.SqlServer.Management.Dac.DacStore($serverconnection)
## Subscribe to the DAC delete events.
$dacstore.add_DacActionStarted({Write-Host `n`nStarting at $(get-date) :: $_.Description})
$dacstore.add_DacActionFinished({Write-Host Completed at $(get-date) :: $_.Description})
## Specify the DAC to delete.
$dacName = "MyApplication"
## Only delete the DAC definition from msdb, the associated database remains active.
$dacstore.Unmanage($dacName)
PowerShell
Пример удаления приложения уровня данных с отсоединением базы данных (PowerShell)
В следующем примере рассматривается удаление приложения уровня данных с названием MyApplication при помощи метода Uninstall(), который позволяет удалить приложение уровня данных с отсоединением базы данных.
## Set a SMO Server object to the default instance on the local computer.
CD SQLSERVER:\SQL\localhost\DEFAULT
$srv = get-item .
## Open a Common.ServerConnection to the same instance.
$serverconnection = New-Object Microsoft.SqlServer.Management.Common.ServerConnection($srv.ConnectionContext.SqlConnectionObject)
$serverconnection.Connect()
$dacstore = New-Object Microsoft.SqlServer.Management.Dac.DacStore($serverconnection)
## Subscribe to the DAC delete events.
$dacstore.add_DacActionStarted({Write-Host `n`nStarting at $(get-date) :: $_.Description})
$dacstore.add_DacActionFinished({Write-Host Completed at $(get-date) :: $_.Description})
## Specify the DAC to delete.
$dacName = "MyApplication"
## Delete the DAC definition from msdb and detach the associated database.
$dacstore.Uninstall($dacName, [Microsoft.SqlServer.Management.Dac.DacUninstallMode]::DetachDatabase)
PowerShell
Пример удаления приложения уровня данных и базы данных (PowerShell)
В следующем примере рассматривается удаление приложения уровня данных с названием MyApplication при помощи метода Uninstall(), который позволяет удалить приложение уровня данных и базу данных.
## Set a SMO Server object to the default instance on the local computer.
CD SQLSERVER:\SQL\localhost\DEFAULT
$srv = get-item .
## Open a Common.ServerConnection to the same instance.
$serverconnection = New-Object Microsoft.SqlServer.Management.Common.ServerConnection($srv.ConnectionContext.SqlConnectionObject)
$serverconnection.Connect()
$dacstore = New-Object Microsoft.SqlServer.Management.Dac.DacStore($serverconnection)
## Subscribe to the DAC delete events.
$dacstore.add_DacActionStarted({Write-Host `n`nStarting at $(get-date) :: $_.Description})
$dacstore.add_DacActionFinished({Write-Host Completed at $(get-date) :: $_.Description})
## Specify the DAC to delete.
$dacName = "MyApplication"
## Delete the DAC definition from msdb and drop the associated database.
## $dacstore.Uninstall($dacName, [Microsoft.SqlServer.Management.Dac.DacUninstallMode]::DropDatabase)
PowerShell
См. также
Основные понятия
Развертывание приложения уровня данных
Регистрация базы данных в качестве приложения уровня данных
Резервное копирование и восстановление баз данных SQL Server