사용자 데이터베이스 이동
SQL Server에서는 ALTER DATABASE 문의 FILENAME 절에 새 파일 위치를 지정하여 사용자 데이터베이스의 데이터, 로그 및 전체 텍스트 카탈로그 파일을 새 위치로 이동할 수 있습니다. 이 방법은 동일한 SQL Server 인스턴스 내에서 데이터베이스 파일을 이동하는 경우에 적용됩니다. 데이터베이스를 다른 SQL Server 인스턴스나 다른 서버로 이동하려면 백업 및 복원 작업이나 분리/연결 작업을 사용합니다.
[!참고]
SQL Server 데이터베이스 엔진의 일부 기능 중 데이터베이스 엔진에서 데이터베이스 파일의 정보를 저장하는 방법이 변경되었습니다. 이러한 기능은 특정 SQL Server 버전으로 제한됩니다. 이러한 기능을 포함하는 데이터베이스는 이러한 기능이 지원되지 않는 SQL Server 버전으로 이동할 수 없습니다. 현재 데이터베이스에 설정된 모든 버전별 기능 목록을 보려면 sys.dm_db_persisted_sku_features 동적 관리 뷰를 사용합니다.
이 항목의 절차를 사용하려면 데이터베이스 파일의 논리적 이름이 필요합니다. 논리적 파일 이름을 가져오려면 sys.master_files 카탈로그 뷰의 name 열을 쿼리합니다.
[!참고]
데이터베이스를 다른 서버 인스턴스로 이동하는 경우 사용자와 응용 프로그램에 일관된 환경을 제공하려면 데이터베이스의 일부 또는 모든 메타데이터를 다시 만들어야 할 수도 있습니다. 자세한 내용은 다른 서버 인스턴스에서 데이터베이스를 사용할 수 있도록 할 때 메타데이터 관리를 참조하십시오.
계획된 재배치 절차
계획된 재배치의 일부로 데이터 또는 로그 파일을 이동하려면 다음 단계를 따릅니다.
다음 문을 실행합니다.
ALTER DATABASE database_name SET OFFLINE;
파일을 새 위치로 이동합니다.
이동한 각 파일에 대해 다음 문을 실행합니다.
ALTER DATABASE database_name MODIFY FILE ( NAME = logical_name, FILENAME = 'new_path\os_file_name' );
다음 문을 실행합니다.
ALTER DATABASE database_name SET ONLINE;
다음 쿼리를 실행하여 파일 변경 내용을 확인합니다.
SELECT name, physical_name AS CurrentLocation, state_desc FROM sys.master_files WHERE database_id = DB_ID(N'<database_name>');
예약된 디스크 유지 관리를 위한 재배치
예약된 디스크 유지 관리 프로세스의 일부로 파일을 재배치하려면 다음 단계를 따릅니다.
이동할 각 파일에 대해 다음 문을 실행합니다.
ALTER DATABASE database_name MODIFY FILE ( NAME = logical_name , FILENAME = 'new_path\os_file_name' );
SQL Server 인스턴스를 중지하거나 시스템을 종료하여 유지 관리를 수행합니다. 자세한 내용은 서비스 중지를 참조하십시오.
파일을 새 위치로 이동합니다.
SQL Server 인스턴스나 서버를 다시 시작합니다. 자세한 내용은 서비스 시작 및 다시 시작을 참조하십시오.
다음 쿼리를 실행하여 파일 변경 내용을 확인합니다.
SELECT name, physical_name AS CurrentLocation, state_desc FROM sys.master_files WHERE database_id = DB_ID(N'<database_name>');
오류 복구 절차
하드웨어 오류로 인해 파일을 이동해야 하는 경우 다음 단계에 따라 파일을 새 위치에 재배치합니다.
중요 |
---|
데이터베이스가 주의 대상 모드에 있거나 복구할 수 없는 상태여서 시작할 수 없는 경우에는 sysadmin 고정 역할의 멤버만 파일을 이동할 수 있습니다. |
SQL Server 인스턴스가 시작된 경우 중지합니다.
명령 프롬프트에서 다음 명령 중 하나를 입력하여 SQL Server 인스턴스를 마스터 전용 복구 모드로 시작합니다.
기본(MSSQLSERVER) 인스턴스의 경우 다음 명령을 실행합니다.
NET START MSSQLSERVER /f /T3608
명명된 인스턴스의 경우 다음 명령을 실행합니다.
NET START MSSQL$instancename /f /T3608
자세한 내용은 방법: SQL Server 인스턴스 시작(net 명령)을 참조하십시오.
이동할 각 파일에 대해 sqlcmd 명령 또는 SQL Server Management Studio를 사용하여 다음 문을 실행합니다.
ALTER DATABASE database_name MODIFY FILE( NAME = logical_name , FILENAME = 'new_path\os_file_name' );
sqlcmd 유틸리티 사용 방법은 sqlcmd 유틸리티 사용을 참조하십시오.
sqlcmd 유틸리티 또는 SQL Server Management Studio를 종료합니다.
SQL Server 인스턴스를 중지합니다.
파일을 새 위치로 이동합니다.
SQL Server 인스턴스를 시작합니다. 예를 들어 다음을 실행합니다. NET START MSSQLSERVER.
다음 쿼리를 실행하여 파일 변경 내용을 확인합니다.
SELECT name, physical_name AS CurrentLocation, state_desc FROM sys.master_files WHERE database_id = DB_ID(N'<database_name>');
예
다음 예에서는 계획된 재배치의 일부로 AdventureWorks2008R2 로그 파일을 새 위치로 이동합니다.
USE master;
GO
-- Return the logical file name.
SELECT name, physical_name AS CurrentLocation, state_desc
FROM sys.master_files
WHERE database_id = DB_ID(N'AdventureWorks2008R2')
AND type_desc = N'LOG';
GO
ALTER DATABASE AdventureWorks2008R2 SET OFFLINE;
GO
-- Physically move the file to a new location.
-- In the following statement, modify the path specified in FILENAME to
-- the new location of the file on your server.
ALTER DATABASE AdventureWorks2008R2
MODIFY FILE ( NAME = AdventureWorks2008R2_Log,
FILENAME = 'C:\NewLoc\AdventureWorks2008R2_Log.ldf');
GO
ALTER DATABASE AdventureWorks2008R2 SET ONLINE;
GO
--Verify the new location.
SELECT name, physical_name AS CurrentLocation, state_desc
FROM sys.master_files
WHERE database_id = DB_ID(N'AdventureWorks2008R2')
AND type_desc = N'LOG';