데이터 계층 애플리케이션 내보내기

적용 대상:SQL ServerAzure SQL DatabaseAzure SQL Managed Instance

배포된 DAC(데이터 계층 애플리케이션) 또는 데이터베이스를 내보내면 데이터베이스의 개체 정의와 테이블에 포함된 모든 데이터가 모두 포함된 내보내기 파일이 만들어집니다. 그런 다음 내보내기 파일을 데이터베이스 엔진의 다른 인스턴스 또는 Azure SQL Database로 가져올 수 있습니다. 내보내기 가져오기 작업을 결합하여 인스턴스 간에 DAC를 마이그레이션하거나, 보관 파일을 만들거나, SQL Database에 배포된 데이터베이스의 온-프레미스 복사본을 만들 수 있습니다.

시작하기 전에

내보내기 프로세스는 두 단계로 DAC 내보내기 파일을 빌드합니다.

  1. 내보내기를 수행하면 DAC 추출 시 DAC 패키지 파일에 DAC 정의가 작성되듯이 내보내기 파일(BACPAC 파일)에 DAC 정의가 작성됩니다. 내보낸 DAC 정의에는 현재 데이터베이스의 모든 개체가 포함됩니다. 내보내기 프로세스가 원래 DAC에서 배포된 데이터베이스에 대해 실행되고 배포 후 데이터베이스에 직접 변경된 경우 내보낸 정의는 원래 DAC에 정의된 개체가 아니라 데이터베이스에 설정된 개체와 일치합니다.

  2. 내보내기에서는 데이터베이스의 모든 테이블에서 데이터를 대량 복사하고 데이터를 내보내기 파일에 통합합니다.

내보내기 프로세스에서는 DAC 버전을 1.0.0.0으로 설정하고 내보내기 파일의 DAC 설명을 빈 문자열로 설정합니다. 데이터베이스가 DAC에서 배포된 경우에는 내보내기 파일의 DAC 정의에 원본 DAC에 지정된 것과 동일한 이름이 포함되고, 그렇지 않은 경우에는 DAC 이름이 데이터베이스 이름으로 설정됩니다.

제한 사항

DAC 또는 데이터베이스는 SQL Database 또는 SQL Server 2005(9.x) SP4(서비스 팩 4) 이상의 데이터베이스에서만 내보낼 수 있습니다.

DAC에서 지원되지 않거나 포함된 사용자가 있는 개체가 있는 데이터베이스는 내보낼 수 없습니다. DAC에서 지원되는 개체 유형에 대한 자세한 내용은 SQL Server 개체 및 버전에 대한 DAC 지원을 참조 하세요.

디스크 공간 부족 메시지와 함께 실패하는 경우 시스템의 %TEMP% 폴더를 고유 데이터 디스크에 상주하도록 구성하는 것이 좋습니다. 이렇게 하면 내보내기 프로세스가 원활하게 실행될 수 있는 충분한 공간을 확보하여 잠재적인 디스크 공간 복잡성을 방지할 수 있습니다.

시스템의 %TEMP% 폴더를 구성하려면 다음을 수행합니다.

  • Windows 키 + 일시 중지/중단을 누르거나 이 PC마우스 오른쪽 단추로 클릭하고 속성을 선택하여 시스템 속성 창을 엽니다.

  • 왼쪽에서 고급 시스템 설정으로 레이블이 지정된 링크를 선택합니다.

  • 이어지는 시스템 속성 창에서 아래쪽으로 이동하여 환경 변수를 선택합니다.

  • 시스템 변수에 레이블이 지정된 섹션에서 TEMP 및 TMP 변수를 찾은 다음, 각각과 연결된 편집을 선택합니다.

  • 두 변수의 값을 수정하여 설정한 별도의 데이터 디스크의 경로를 가리킵니다. 예를 들어 데이터 디스크가 로 D:지정된 경우 값을 .로 D:\Temp설정합니다.

  • 확인을 선택하고 열려 있는 모든 창을 닫아 변경 내용을 확인합니다.

사용 권한

DAC를 내보내려면 ALTER ANY 로그인 및 데이터베이스 수준 VIEW DEFINITION 권한 및 s에 대한sys.sql_expression_dependencies SELECT 권한을 소유해야 합니다. 이 작업은 securityadmin 고정 서버 역할의 멤버 자격을 보유하는 개인과 DAC의 원본 데이터베이스 내에서 database_owner 고정 데이터베이스 역할을 수행할 수 있습니다. 또한 sysadmin 고정 서버 역할의 일부이거나 sa라는 기본 제공 SQL Server 시스템 관리자 계정에 액세스할 수 있는 사용자에게 DAC를 내보낼 수 있습니다.

Azure SQL Database에서 모든 테이블 또는 특정 테이블에 대해 각 데이터베이스 VIEW DEFINITION 및 SELECT 권한을 부여해야 합니다.

데이터 계층 애플리케이션 내보내기 마법사 사용

마법사를 사용하여 DAC를 내보내려면

  1. 온-프레미스 또는 SQL Database에서 SQL Server 인스턴스에 연결합니다.

  2. 개체 탐색기에서 DAC를 내보낼 인스턴스의 노드를 확장합니다.

  3. 데이터베이스 이름을 마우스 오른쪽 단추로 클릭합니다.

  4. 작업을 선택한 다음, 데이터 계층 애플리케이션 내보내기...를 선택합니다.

  5. 마법사 대화 상자를 완료합니다.

소개 페이지

이 페이지에서는 데이터 계층 애플리케이션 내보내기 마법사의 단계에 대해 설명합니다.

옵션

이 페이지를 다시 표시 안 함 - 나중에 소개 페이지가 표시되지 않도록 하려면 확인란을 선택합니다.

다음 - DAC 패키지 선택 페이지로 진행합니다.

취소 - 작업을 취소하고 마법사를 닫습니다.

내보내기 설정 페이지

이 페이지에서는 BACPAC 파일을 만들려는 위치를 지정할 수 있습니다.

  • 로컬 디스크 에 저장 - 로컬 컴퓨터의 디렉터리에 BACPAC 파일을 만듭니다. 찾아보기를 선택하여 로컬 컴퓨터를 탐색하거나 제공된 공간에서 경로를 지정합니다. 경로 이름에는 파일 이름과 .bacpac 확장명을 포함해야 합니다.

  • Azure에 저장 - Azure 컨테이너에 BACPAC 파일을 만듭니다. 이 옵션의 유효성을 검사하려면 Azure 컨테이너에 연결해야 합니다. 또한 이 옵션을 사용하려면 임시 파일에 대한 로컬 디렉터리를 지정해야 합니다. 임시 파일은 지정된 위치에 만들어지고 작업이 완료된 후 해당 위치에 유지됩니다.

내보낼 테이블의 하위 집합을 지정하려면 고급 옵션을 사용합니다.

유효성 검사 페이지

유효성 검사 페이지를 사용하여 작업을 차단하는 문제를 검토합니다. 계속하려면 차단 문제를 해결한 다음 유효성 검사를 다시 실행하여 유효성 검사가 성공하는지 확인합니다.

계속하려면 다음을 선택합니다.

요약 페이지

이 페이지에서 작업에 대해 지정한 원본 및 대상 설정을 검토할 수 있습니다. 지정된 설정을 사용하여 내보내기 작업을 완료하려면 마침을 선택합니다. 내보내기 작업을 취소하고 마법사를 종료하려면 취소를 선택합니다.

진행률 페이지

이 페이지에는 작업 상태를 나타내는 진행률 표시줄이 표시됩니다. 자세한 상태를 보려면 세부 정보 보기 옵션을 선택합니다.

결과 페이지

이 페이지에서는 내보내기 작업의 성공 또는 실패를 보고하고 각 작업의 결과를 보여 줍니다. 오류가 발생한 모든 작업에는 결과 열에 링크가 있습니다. 링크를 선택하여 해당 작업에 대한 오류 보고서를 봅니다.

마침을 선택하여 마법사를 닫습니다.

.NET Framework 애플리케이션 사용

.Net Framework 애플리케이션에서 Export() 메서드를 사용하여 DAC를 내보내려면

  1. SMO Server 개체를 만들고 내보낼 DAC가 포함된 인스턴스로 설정합니다.

  2. ServerConnection 개체를 열고 동일한 인스턴스에 연결합니다.

  3. Export 형식의 Microsoft.SqlServer.Management.Dac.DacStore 메서드를 사용하여 DAC를 내보냅니다. 내보낼 DAC의 이름과 내보내기 파일을 배치할 폴더의 경로를 지정합니다.

참고 항목