다음을 통해 공유


파일 및 파일 그룹 복원(SQL Server)

적용 대상: SQL Server

이 항목에서는 SQL Server Management Studio 또는 Transact-SQL을 사용하여 SQL Server에서 파일과 파일 그룹을 복원하는 방법을 설명합니다.

항목 내용

시작하기 전에

제한 사항

  • 복원될 데이터베이스를 현재 사용하고 있는 사람만 파일과 파일 그룹을 복원하는 시스템 관리자가 될 수 있습니다.

  • RESTORE는 명시적 또는 암시적 트랜잭션에서 사용할 수 없습니다.

  • 단순 복구 모델에서 파일은 읽기 전용 파일 그룹에 속해야 합니다.

  • 전체 복구 모델 또는 대량 로그 복구 모델의 경우 파일을 복원하려면 먼저 활성 트랜잭션 로그(비상 로그라고도 함)를 백업해야 합니다. 자세한 내용은 트랜잭션 로그 백업(SQL Server)을 참조하세요.

  • 암호화된 데이터베이스를 복원하려면 데이터베이스를 암호화하는 데 사용된 인증서 또는 비대칭 키에 대한 액세스 권한이 있어야 합니다. 인증서 또는 비대칭 키가 없으면 데이터베이스를 복원할 수 없습니다. 따라서 데이터베이스 암호화 키를 암호화하는 데 사용되는 인증서는 백업이 필요한 동안에는 유지되어야 합니다. 자세한 내용은 SQL Server Certificates and Asymmetric Keys을 참조하세요.

보안

사용 권한

복원할 데이터베이스가 없으면 CREATE DATABASE 권한이 있어야 RESTORE를 실행할 수 있습니다. 데이터베이스가 있으면 RESTORE 권한은 기본적으로 sysadmindbcreator 고정 서버 역할의 멤버와 데이터베이스의 소유자(dbo)에 설정됩니다. FROM DATABASE_SNAPSHOT 옵션의 경우 데이터베이스가 항상 있습니다.

멤버 자격 정보를 서버에서 항상 사용할 수 있는 역할에 RESTORE 권한이 제공됩니다. 고정 데이터베이스 역할의 멤버 자격은 데이터베이스가 액세스 가능한 상태이며 손상되지 않은 경우에만 확인할 수 있는데, RESTORE 실행 시 데이터베이스가 항상 이러한 상태인 것은 아니므로 db_owner 고정 데이터베이스 역할의 멤버에게는 RESTORE 권한이 없습니다.

SQL Server Management Studio 사용

파일과 파일 그룹을 복원하려면

  1. SQL Server 데이터베이스 엔진의 적절한 인스턴스에 연결한 후 개체 탐색기에서 서버 이름을 클릭하여 서버 트리를 확장합니다.

  2. 데이터베이스를 확장합니다. 데이터베이스에 따라 사용자 데이터베이스를 선택하거나 시스템 데이터베이스를 확장한 다음 시스템 데이터베이스를 선택합니다.

  3. 데이터베이스를 마우스 오른쪽 단추로 클릭하고 작업을 가리킨 다음 복원을 클릭합니다.

  4. 파일 및 파일 그룹 복원 대화 상자를 여는 파일 및 파일 그룹을 클릭합니다.

  5. 일반 페이지의 대상 데이터베이스 목록 상자에 복원할 데이터베이스를 입력합니다. 새 데이터베이스를 입력하거나 드롭다운 목록에서 기존 데이터베이스를 선택할 수 있습니다. 목록에는 시스템 데이터베이스 마스터tempdb를 제외한 서버의 모든 데이터베이스가 포함됩니다.

  6. 복원할 백업 세트의 소스와 위치를 지정하려면 다음 옵션 중 하나를 클릭합니다.

    • 데이터베이스 소스

      목록 상자에 데이터베이스 이름을 입력합니다. 이 목록에는 msdb 백업 기록에 따라 백업된 데이터베이스만 포함됩니다.

    • 디바이스

      찾아보기 단추를 클릭합니다. 백업 디바이스 지정 대화 상자에서 백업 미디어 유형 목록 상자에 나열된 디바이스 유형 중 하나를 선택합니다. 백업 미디어 목록 상자에서 하나 이상의 디바이스를 선택하려면 추가를 클릭합니다.

      백업 미디어 목록 상자에 원하는 디바이스를 추가한 후 확인을 클릭하여 일반 페이지로 돌아갑니다.

  7. 복원에 사용할 백업 세트 선택 그리드에서 복원할 백업을 선택합니다. 이 표는 지정한 위치에서 사용 가능한 백업을 표시합니다. 기본적으로 복구 계획이 제안됩니다. 제안된 복구 계획을 재정의하려면 표에서 선택 항목을 변경할 수 있습니다. 선택 취소된 백업에 의존하는 모든 백업은 자동으로 선택 취소됩니다.

    열 머리
    복원 선택한 확인란은 복원할 백업 집합을 나타냅니다.
    이름 백업 세트의 이름입니다.
    파일 유형 백업의 데이터 형식인 데이터, 로그또는 Filestream 데이터를 지정합니다. 테이블에 포함된 데이터는 데이터 파일에 있습니다. 트랜잭션 로그 데이터는 로그 파일에 있습니다. 파일 시스템에 저장된 BLOB(Binary Large Object) 데이터는 Filestream 데이터 파일에 있습니다.
    Type 수행된 백업 유형입니다. 전체, 차등 또는 트랜잭션 로그일 수 있습니다.
    서버 백업 작업을 수행한 데이터베이스 엔진 인스턴스의 이름입니다.
    테이블 논리 이름 파일의 논리적 이름입니다.
    데이터베이스 백업 작업에 포함된 데이터베이스의 이름입니다.
    시작 날짜 클라이언트의 국가별 설정으로 표시되는 백업 작업 시작 날짜 및 시간입니다.
    완료 날짜 클라이언트의 국가별 설정으로 표시되는 백업 작업 완료 날짜 및 시간입니다.
    크기 백업 세트의 크기(바이트)입니다.
    사용자 이름 백업 작업을 수행한 사용자의 이름입니다.
  8. 고급 옵션을 보거나 선택하려면 페이지 선택 창에서 옵션을 클릭합니다.

  9. 복원 옵션 패널에서 상황에 적합한 경우 다음 옵션 중 하나를 선택할 수 있습니다.

    파일 그룹으로 복원
    전체 파일 그룹을 복원함을 나타냅니다.

    기존 데이터베이스 덮어쓰기
    다른 데이터베이스 또는 파일이 동일한 이름으로 이미 있는 경우에도 복원 작업이 기존 데이터베이스 및 해당 관련 파일을 덮어쓰도록 지정합니다.

    이 옵션을 선택하는 것은 Transact-SQL RESTORE 문에서 REPLACE 옵션을 사용하는 것과 같습니다.

    각 백업 복원 전에 확인
    각 백업 세트를 복원하기 전에 확인을 요청합니다.

    이 옵션은 서버에 하나의 테이프 디바이스가 있을 때와 같이 여러 미디어 세트의 테이프를 바꿔야 할 경우에 특히 유용합니다.

    복원된 데이터베이스에 대한 액세스 제한
    복원된 데이터베이스를 db_owner, dbcreator, 또는 sysadmin의 멤버만 사용할 수 있도록 합니다.

    이 옵션을 선택하는 것은 Transact-SQL RESTORE 문에서 RESTRICTED_USER 옵션을 사용하는 것과 같습니다.

  10. 필요에 따라 데이터베이스 복원 파일의 각 파일에 대한 새 복원 대상을 그리드로 지정하여 데이터베이스를 새 위치로 복원할 수 있습니다.

    열 머리
    원본 파일 이름 원본 백업 파일의 전체 경로입니다.
    파일 유형 백업의 데이터 형식인 데이터, 로그또는 Filestream 데이터를 지정합니다. 테이블에 포함된 데이터는 데이터 파일에 있습니다. 트랜잭션 로그 데이터는 로그 파일에 있습니다. 파일 시스템에 저장된 BLOB(Binary Large Object) 데이터는 Filestream 데이터 파일에 있습니다.
    다음으로 복원 복원할 데이터베이스 파일의 전체 경로입니다. 새 복원 파일을 지정하려면 텍스트 상자를 클릭하고 제안된 경로 및 파일 이름을 편집합니다. 다른 이름으로 복원 열에서 경로 또는 파일 이름을 변경하는 것은 Transact-SQL RESTORE 문의 MOVE 옵션을 사용하는 것과 같습니다.
  11. 복구 상태 패널은 복원 작업 후의 데이터베이스 상태를 결정합니다.

커밋되지 않은 트랜잭션을 롤백하여 데이터베이스를 사용할 수 있는 상태로 유지합니다. 추가 트랜잭션 로그는 복원할 수 없습니다. 없습니다(RESTORE WITH RECOVERY).
데이터베이스를 복구합니다. 이 옵션은 기본 동작입니다. 필요한 모든 백업을 지금 복원하는 경우에만 이 옵션을 선택합니다. 이 옵션은 Transact-SQL RESTORE 문에서 WITH RECOVERY를 지정하는 것과 같습니다.

데이터베이스를 비작동 상태로 유지하고 커밋되지 않은 트랜잭션을 롤백하지 않습니다. 추가 트랜잭션 로그를 복원할 수 있습니다. 있습니다(RESTORE WITH NORECOVERY).
데이터베이스를 복원 상태로 유지합니다. 데이터베이스를 복구하려면 앞의 RESTORE WITH RECOVERY 옵션을 사용하여 다른 복원을 수행해야 합니다(위의 내용 참조). 이 옵션은 Transact-SQL RESTORE 문에서 WITH NORECOVERY를 지정하는 것과 같습니다.

이 옵션을 선택하면 복제 설정 유지 옵션을 사용할 수 없습니다.

데이터베이스를 읽기 전용 모드로 유지합니다. 커밋되지 않은 트랜잭션을 롤백하지만 복구 효과를 실행 취소할 수 있도록 파일에 롤백 작업을 저장합니다. 저장합니다(RESTORE WITH STANDBY).
데이터베이스를 대기 상태로 둡니다. 이 옵션은 Transact-SQL RESTORE 문에서 WITH STANDBY를 지정하는 것과 같습니다.

이 옵션을 선택하려면 대기 파일을 지정해야 합니다.

롤백 실행 취소 파일
롤백 실행 취소 파일 텍스트 상자에 대기 파일 이름을 지정합니다. 이 옵션은 데이터베이스를 읽기 전용 모드(RESTORE WITH STANDBY)로 두는 경우에 필요합니다.

Transact-SQL 사용

파일과 파일 그룹을 복원하려면

  1. RESTORE DATABASE 문을 실행하여 파일 그룹의 파일을 복원합니다. 이때 다음을 지정합니다.

    • 복원된 데이터베이스의 이름입니다.

    • 전체 데이터베이스 백업을 복원하는 백업 디바이스입니다.

    • 복원할 각 파일에 대한 FILE 절

    • 복원할 각 파일 그룹에 대한 FILEGROUP 절입니다.

    • NORECOVERY 절입니다. 백업을 만든 후 파일이 수정되지 않은 경우 RECOVERY 절을 지정합니다.

  2. 파일 백업을 만든 후에 파일이 수정된 경우에는 RESTORE LOG 문을 실행하여 트랜잭션 로그 백업을 적용합니다. 이때 다음을 지정합니다.

    • 트랜잭션 로그가 적용될 데이터베이스의 이름

    • 트랜잭션 로그 백업이 복원될 백업 디바이스입니다.

    • 현재 백업 후에 적용할 다른 트랜잭션 로그 백업이 있는 경우 NORECOVERY 절입니다. 그렇지 않으면 RECOVERY 절을 지정합니다.

      트랜잭션 로그 백업을 적용할 경우, 모든 데이터베이스 파일이 복원되지 않는 한 파일과 파일 그룹이 백업된 시간부터 로그가 끝날 때까지의 시간을 포함해야 합니다.

예(Transact-SQL)

다음은 MyDatabase 데이터베이스의 파일 및 파일 그룹을 복원하는 예제입니다. 데이터베이스를 현재 시간으로 복원하기 위해 두 개의 트랜잭션 로그가 적용됩니다.

USE master;  
GO  
-- Restore the files and filegroups for MyDatabase.  
RESTORE DATABASE MyDatabase  
   FILE = 'MyDatabase_data_1',  
   FILEGROUP = 'new_customers',  
   FILE = 'MyDatabase_data_2',  
   FILEGROUP = 'first_qtr_sales'  
   FROM MyDatabase_1  
   WITH NORECOVERY;  
GO  
-- Apply the first transaction log backup.  
RESTORE LOG MyDatabase  
   FROM MyDatabase_log1  
   WITH NORECOVERY;  
GO  
-- Apply the last transaction log backup.  
RESTORE LOG MyDatabase  
   FROM MyDatabase_log2  
   WITH RECOVERY;  
GO  

참고 항목

Restore a Database Backup Using SSMS
파일 및 파일 그룹 백업(SQL Server)
전체 데이터베이스 백업 만들기(SQL Server)
트랜잭션 로그 백업(SQL Server)
트랜잭션 로그 백업 복원(SQL Server)
RESTORE(Transact-SQL)