mssql 사용자 데이터베이스 이동(mdf, ldf 위치 변경)
DB Skill/MSSQL 2021. 8. 19. 00:04
일반적으로 동일한 SQL Server 인스턴스 내에서 파일 이동이 필요할 경우에 이 방법을 사용하며, 만약 다른 인스턴스나 다른 SQL Server로 이동한다면 분리 및 연결(sp_attach_db, sp_detach_db 시스템 저장 프로시져) 방법 또는 백업 및 복원 방법을 이용하면 됩니다.
[시나리오]
1. 데이터베이스명 : TestDB
2. 변경 전 파일 경로
1) C:\Program Files\Microsoft SQL Server\MSSQL.1\MSSQL\DATA\TestDB.mdf
2) C:\Program Files\Microsoft SQL Server\MSSQL.1\MSSQL\DATA\TestDB_log.ldf
3. 변경 후 파일 경로
1) D:\Data\TestDB.mdf
2) D:\Data\TestDB_log.ldf
[작업절차]
USE MASTER
GO
-- 1. 파일의 논리 이름을 확인합니다.
SELECT file_id, name, physical_name FROM sys.master_files WHERE database_id = db_id('LAIGO');
/* LAIGO, LAIGO_LOG */
-- 2. 30초 후 모든 작업을 롤백하고 단일 사용자 모드로 전환합니다.
ALTER DATABASE LAIGO SET SINGLE_USER WITH ROLLBACK AFTER 30
-- 3. LAIGO 데이터베이스 오프라인 상태로 전환합니다.
ALTER DATABASE LAIGO SET OFFLINE
-- 4. mdf,ldf 파일 위치를 변경합니다.
-- 5. mdf 파일 위치 정보를 변경합니다.
ALTER DATABASE LAIGO MODIFY FILE (NAME=LAIGO, FILENAME='d:\data\laigo.mdf')
-- 6. ldf 파일 위치 정보를 변경합니다.
ALTER DATABASE LAIGO MODIFY FILE (NAME=LAIGO_LOG, FILENAME='d:\data\laigo_log.ldf')
-- 7. 데이버테이스를 온라인 상태로 전환합니다.
ALTER DATABASE LAIGO SET ONLINE
--8. 멀티 사용자 모드로 변경합니다.
ALTER DATABASE LAIGO SET MULTI_USER
-- 9. 정상적으로 변경되었는지 확인합니다.
SELECT name, physical_name AS CurrentLocation, state_desc FROM sys.master_files
WHERE database_id = DB_ID(N'LAIGO');
참고 : https://laigo.kr/76 [Lai Go's Blog]
'DB Skill > MSSQL' 카테고리의 다른 글
mssql vlf count 확인 및 축소 (0) | 2021.08.19 |
---|---|
mssql waitresource 기반 page정보로 table 및 index 확인 (0) | 2021.08.19 |
mssql tempdb 물리적 위치 변경 (0) | 2021.08.18 |
mssql table identity 확인 및 변경 ( DBCC CHECKIDENT 사용 ) (0) | 2021.08.18 |
mssql sqlhandle기반 query plan 확인 (0) | 2021.08.18 |