다음을 통해 공유


CREATE DATABASE

새 데이터베이스를 만듭니다.

작업 중인 특정 SQL 버전에 대한 구문, 인수, 설명, 사용 권한 및 예제를 보려면 다음 탭 중 하나를 선택합니다.

제품 선택

다음 행에서 관심 있는 제품 이름을 선택하면 해당 제품의 정보만 표시됩니다.

* SQL Server *  

 

SQL Server

개요

SQL Server에서 이 문은 새 데이터베이스 및 사용되는 파일과 해당 파일 그룹을 만듭니다. 또한 데이터베이스 스냅샷을 만드는 데 사용하거나, 데이터베이스 파일을 첨부하여 다른 데이터베이스의 분리된 파일에서 데이터베이스를 만드는 데 사용할 수도 있습니다.

구문

데이터베이스 만들기

구문 표기 규칙에 대한 자세한 내용은 Transact-SQL 구문 표기 규칙을 참조하세요.

CREATE DATABASE database_name
[ CONTAINMENT = { NONE | PARTIAL } ]
[ ON
      [ PRIMARY ] <filespec> [ ,...n ]
      [ , <filegroup> [ ,...n ] ]
      [ LOG ON <filespec> [ ,...n ] ]
]
[ COLLATE collation_name ]
[ WITH <option> [,...n ] ]
[;]

<option> ::=
{
      FILESTREAM ( <filestream_option> [,...n ] )
    | DEFAULT_FULLTEXT_LANGUAGE = { lcid | language_name | language_alias }
    | DEFAULT_LANGUAGE = { lcid | language_name | language_alias }
    | NESTED_TRIGGERS = { OFF | ON }
    | TRANSFORM_NOISE_WORDS = { OFF | ON }
    | TWO_DIGIT_YEAR_CUTOFF = <two_digit_year_cutoff>
    | DB_CHAINING { OFF | ON }
    | TRUSTWORTHY { OFF | ON }
    | PERSISTENT_LOG_BUFFER=ON ( DIRECTORY_NAME='path-to-directory-on-a-DAX-volume' )
    | LEDGER = {ON | OFF }
}

<filestream_option> ::=
{
      NON_TRANSACTED_ACCESS = { OFF | READ_ONLY | FULL }
    | DIRECTORY_NAME = 'directory_name'
}

<filespec> ::=
{
(
    NAME = logical_file_name ,
    FILENAME = { 'os_file_name' | 'filestream_path' }
    [ , SIZE = size [ KB | MB | GB | TB ] ]
    [ , MAXSIZE = { max_size [ KB | MB | GB | TB ] | UNLIMITED } ]
    [ , FILEGROWTH = growth_increment [ KB | MB | GB | TB | % ] ]
)
}

<filegroup> ::=
{
FILEGROUP filegroup name [ [ CONTAINS FILESTREAM ] [ DEFAULT ] | CONTAINS MEMORY_OPTIMIZED_DATA ]
    <filespec> [ ,...n ]
}

데이터베이스 연결

CREATE DATABASE database_name
    ON <filespec> [ ,...n ]
    FOR { { ATTACH [ WITH <attach_database_option> [ , ...n ] ] }
        | ATTACH_REBUILD_LOG }
[;]

<attach_database_option> ::=
{
      <service_broker_option>
    | RESTRICTED_USER
    | FILESTREAM ( DIRECTORY_NAME = { 'directory_name' | NULL } )
}

<service_broker_option> ::=
{
    ENABLE_BROKER
  | NEW_BROKER
  | ERROR_BROKER_CONVERSATIONS
}

데이터베이스 스냅샷 만들기

CREATE DATABASE database_snapshot_name
    ON
    (
        NAME = logical_file_name,
        FILENAME = 'os_file_name'
    ) [ ,...n ]
    AS SNAPSHOT OF
[;]

인수

database_name

새 데이터베이스의 이름입니다. 데이터베이스 이름은 SQL Server 인스턴스 내에서 고유해야 하고 식별자 규칙을 따라야 합니다.

로그 파일에 논리적 이름을 지정하는 경우 database_name은 최대 128자가 될 수 있습니다. 논리적 로그 파일 이름을 지정하지 않으면 SQL Server는 database_name에 접미사를 추가하여 로그의 logical_file_nameos_file_name을 생성합니다. 생성할 논리적 파일 이름이 128자를 넘지 않도록 database_name은 123자로 제한됩니다.

데이터 파일 이름을 지정하지 않으면 SQL Server는 database_namelogical_file_nameos_file_name으로 사용합니다. 기본 경로는 레지스트리에서 가져옵니다. 기본 경로는 Management Studio의 서버 속성(데이터베이스 설정 페이지)에서 변경할 수 있습니다. 기본 경로를 변경하려면 SQL Server를 다시 시작해야 합니다.

CONTAINMENT = { NONE | PARTIAL }

적용 대상: SQL Server 2012(11.x) 이상

데이터베이스의 포함 상태를 지정합니다. NONE = 포함되지 않은 데이터베이스입니다. PARTIAL = 부분적으로 포함된 데이터베이스입니다.

켜기

데이터베이스의 데이터 섹션을 저장하는 데 사용하는 디스크 파일인 데이터 파일을 명시적으로 정의하도록 지정합니다. 주 파일 그룹의 데이터 파일을 정의하는 <filespec> 항목의 쉼표로 구분된 목록을 나열할 때는 ON이 필요합니다. 주 파일 그룹의 파일 목록 다음에는 필요에 따라 사용자 파일 그룹과 해당 파일을 정의하는 쉼표로 구분된 <filegroup> 항목의 목록이 올 수 있습니다.

PRIMARY

연결된 <filespec> 목록이 주 파일을 정의하도록 지정합니다. 주 파일 그룹의 <filespec> 항목에서 지정한 첫 번째 파일이 주 파일이 됩니다. 데이터베이스에는 주 파일이 하나만 있을 수 있습니다. 자세한 내용은 Database Files and Filegroups을 참조하세요.

PRIMARY를 지정하지 않으면 CREATE DATABASE 문에 나열된 첫 번째 파일이 주 파일이 됩니다.

LOG ON

데이터베이스 로그를 저장하는 데 사용하는 디스크 파일인 로그 파일을 명시적으로 정의하도록 지정합니다. LOG ON 다음에는 로그 파일을 정의하는 쉼표로 구분된 <filespec> 항목의 목록이 옵니다. LOG ON을 지정하지 않은 경우에는 데이터베이스의 모든 데이터 파일 크기를 합한 값의 25% 또는 512KB 중에서 더 큰 값을 갖는 로그 파일 하나가 자동으로 만들어집니다. 이 파일은 기본 로그 파일 위치에 저장됩니다. 이 위치에 대한 자세한 내용은 SSMS에서 데이터 및 로그 파일의 기본 위치 보기 또는 변경을 참조하세요.

데이터베이스 스냅샷에는 LOG ON을 지정할 수 없습니다.

COLLATE collation_name

데이터베이스의 기본 데이터 정렬을 지정합니다. 데이터 정렬 이름으로는 Windows 데이터 정렬 이름 또는 SQL 데이터 정렬 이름을 사용할 수 있습니다. 이 인수를 지정하지 않으면 데이터베이스에 SQL Server 인스턴스의 기본 데이터 정렬이 할당됩니다. 데이터베이스 스냅샷에는 데이터 정렬 이름을 지정할 수 없습니다.

FOR ATTACH 또는 FOR ATTACH_REBUILD_LOG 절을 사용하여 데이터 정렬 이름을 지정할 수 없습니다. 연결된 데이터베이스의 데이터 정렬을 변경하는 방법은 Microsoft 웹 사이트를 참조하세요.

Windows 데이터 정렬 이름 및 SQL 데이터 정렬 이름에 대한 자세한 내용은 COLLATE를 참조하세요.

참고

포함된 데이터베이스는 포함되지 않은 데이터베이스와 다른 방식으로 데이터가 정렬됩니다. 자세한 내용은 Contained Database Collations를 참조하세요.

WITH <option>

<filestream_option>

NON_TRANSACTED_ACCESS = { OFF | READ_ONLY | FULL }

적용 대상: SQL Server 2012(11.x) 이상

데이터베이스에 대한 비트랜잭션 FILESTREAM 액세스 수준을 지정합니다.

설명
OFF 비트랜잭션 액세스는 사용할 수 없습니다.
READONLY 비트랜잭션 프로세스에서 이 데이터베이스의 FILESTREAM 데이터를 읽을 수 있습니다.
FULL FILESTREAM FileTable에 대한 전체 비트랜잭션 액세스를 사용할 수 있습니다.

DIRECTORY_NAME = <directory_name>

적용 대상: SQL Server 2012(11.x) 이상

Windows 호환 디렉터리 이름입니다. 이 이름은 SQL Server 인스턴스의 모든 Database_Directory 이름 중에서 고유해야 합니다. 고유성을 비교할 때는 SQL Server 데이터 정렬 설정과 관계없이 대/소문자가 구분되지 않습니다. 데이터베이스에 FileTable을 만들기 전에 이 옵션을 설정해야 합니다.



CONTAINMENT가 PARTIAL로 설정된 경우에만 다음 옵션을 사용할 수 있습니다. CONTAINMENT가 NONE으로 설정되어 있으면 오류가 발생합니다.

DEFAULT_FULLTEXT_LANGUAGE = <lcid> | <언어 이름> | <언어 별칭>

적용 대상: SQL Server 2012(11.x) 이상

이 옵션에 대한 전체 설명은 기본 전체 텍스트 언어 서버 구성 옵션 구성을 참조하세요.

DEFAULT_LANGUAGE = <lcid> | <언어 이름> | <언어 별칭>

적용 대상: SQL Server 2012(11.x) 이상

이 옵션에 대한 전체 설명은 기본 언어 서버 구성 옵션 구성을 참조하세요.

NESTED_TRIGGERS = { OFF | ON}

적용 대상: SQL Server 2012(11.x) 이상

이 옵션에 대한 전체 설명은 nested triggers 서버 구성 옵션 구성을 참조하세요.

TRANSFORM_NOISE_WORDS = { OFF | ON}

적용 대상: SQL Server 2012(11.x) 이상

이 옵션에 대한 전체 설명은 변환 노이즈 단어 서버 구성 옵션을 참조하세요.

TWO_DIGIT_YEAR_CUTOFF = { 2049 | <1753년에서 9999> 년 사이의 모든 연도 }

연도를 나타내는 4자리 숫자입니다. 기본값은 2049입니다. 이 옵션에 대한 자세한 내용은 두 자리 연도 구분 서버 구성 옵션 구성을 참조하세요.

DB_CHAINING { OFF | ON }

ON이 지정되면 데이터베이스가 데이터베이스 간 소유권 체인의 원본 또는 대상이 될 수 있습니다.

OFF가 지정되면 데이터베이스가 데이터베이스 간 소유권 체인에 참여할 수 없습니다. 기본값은 OFF입니다.

중요

SQL Server 인스턴스는 cross db ownership chaining 서버 옵션이 0(OFF)일 때 이 설정을 인식할 수 있습니다. cross db ownership chaining이 1(ON)이면 모든 사용자 데이터베이스는 이 옵션 값에 관계없이 데이터베이스 간 소유권 체인에 참여할 수 있습니다. 이 옵션은 sp_configure를 사용하여 설정합니다.

이 옵션을 설정하려면 sysadmin 고정 서버 역할의 멤버 자격이 필요합니다. DB_CHAINING 옵션은 master, model, tempdb 시스템 데이터베이스에서는 설정할 수 없습니다.

TRUSTWORTHY { OFF | ON }

ON이 지정되면 뷰, 사용자 정의 함수 또는 저장 프로시저와 같이 가장 컨텍스트를 사용하는 데이터베이스 모듈이 데이터베이스 외부 리소스에 액세스할 수 있습니다.

OFF가 지정되면 가장 컨텍스트의 데이터베이스 모듈이 데이터베이스 외부의 리소스에 액세스할 수 없습니다. 기본값은 OFF입니다.

TRUSTWORTHY는 데이터베이스가 연결될 때마다 OFF로 설정됩니다.

기본적으로 msdb 데이터베이스를 제외한 모든 시스템 데이터베이스는 TRUSTWORTHY가 OFF로 설정되어 있습니다. modeltempdb 데이터베이스의 경우 이 값을 변경할 수 없습니다. master 데이터베이스의 경우 TRUSTWORTHY 옵션을 ON으로 설정하지 않는 것이 좋습니다.

PERSISTENT_LOG_BUFFER=ON ( DIRECTORY_NAME='' )

적용 : SQL Server 2017 (14.x) 이상.

이 옵션을 지정하면 트랜잭션 로그 버퍼는 스토리지 클래스 메모리(NVDIMM-N 비휘발성 스토리지)로 지원되는 디스크 디바이스에 있는 볼륨에서 생성되며 영구적 로그 버퍼라고도 합니다. 자세한 내용은 스토리지 클래스 메모리 사용하여 트랜잭션 커밋 대기 시간 가속을 참조하고 데이터베이스영구 로그 버퍼를 추가합니다.

LEDGER = {ON | OFF}

ON으로 설정된 경우 모든 사용자 데이터의 무결성이 보호되는 원장 데이터베이스를 만듭니다. 원장 데이터베이스에는 원장 테이블만 만들 수 있습니다. 기본값은 OFF입니다. 데이터베이스를 만든 후에는 LEDGER 옵션 값을 변경할 수 없습니다. 자세한 내용은 원장 데이터베이스 구성을 참조하세요.

CREATE DATABASE ... FOR ATTACH [ WITH < attach_database_option > ]

기존 운영 체제 파일 세트를 연결하여 데이터베이스를 만들도록 지정합니다. 여기에는 주 파일을 지정하는 <filespec> 항목이 반드시 필요합니다. 또한 데이터베이스를 처음 만들었거나 마지막으로 연결했을 때 경로가 다른 파일에 대한 <filespec> 항목이 필요합니다. 이러한 파일에는 반드시 <filespec> 항목을 지정해야 합니다.

FOR ATTACH를 사용하려면 다음과 같은 조건을 충족해야 합니다.

  • 모든 데이터 파일(MDF 및 NDF)을 사용할 수 있어야 합니다.
  • 로그 파일이 여러 개 있는 경우 해당 파일을 모두 사용할 수 있어야 합니다.

읽기/쓰기 데이터베이스에 현재 사용할 수 없는 단일 로그 파일이 있고 작업 ATTACH 전에 FOR ATTACH 사용자 또는 열린 트랜잭션 없이 데이터베이스가 종료된 경우 자동으로 로그 파일을 다시 빌드하고 기본 파일을 업데이트합니다. 반면에 읽기 전용 데이터베이스의 경우에는 주 파일을 업데이트할 수 없으므로 로그를 다시 작성할 수 없습니다. 따라서 사용할 수 없는 로그와 읽기 전용 데이터베이스를 연결할 때는 로그 파일 또는 FOR ATTACH 절 내의 파일을 제공해야 합니다.

참고

최신 버전의 SQL Server에서 만든 데이터베이스를 이전 버전에서 연결할 수 없습니다.

SQL Server에서는 연결 중인 데이터베이스에 속한 모든 전체 텍스트 파일이 데이터베이스에 연결됩니다. 전체 텍스트 카탈로그의 새 경로를 지정하려면 전체 텍스트 운영 체제 파일 이름을 제외한 새 위치를 지정합니다. 자세한 내용은 예 섹션을 참조하십시오.

FILESTREAM 옵션 "Directory name"을 포함하는 데이터베이스를 SQL Server 인스턴스에 연결하면 SQL Server에 Database_Directory 이름이 고유한지 확인하라는 메시지가 표시됩니다. 그렇지 않으면 ATTACH 오류가 FILESTREAM Database_Directory name is not unique in this SQL Server instance발생하여 작업이 실패합니다. 이 오류를 방지하려면 선택적 매개 변수 directory_name이 이 작업에 전달되어야 합니다.

데이터베이스 스냅샷에는 FOR ATTACH를 지정할 수 없습니다.

FOR ATTACH에 RESTRICTED_USER 옵션을 지정할 수 있습니다. RESTRICTED_USER는 db_owner 고정 데이터베이스 역할 및 dbcreator와 sysadmin 고정 서버 역할의 멤버만 데이터베이스로의 연결을 허용하지만 연결되는 수는 제한하지 않습니다. 자격이 없는 사용자의 연결 시도는 거부됩니다.

<service_broker_option>

데이터베이스에서 Service Broker를 사용하는 경우 다음과 같이 FOR ATTACH 절에 WITH <service_broker_option>을 사용합니다.

데이터베이스에 대한 Service Broker 메시지 배달 및 Service Broker 식별자를 제어합니다. Service Broker 옵션은 FOR ATTACH 절을 사용할 때만 지정할 수 있습니다.

ENABLE_BROKER

지정된 데이터베이스에 대해 Service Broker를 사용할 수 있도록 지정합니다. 즉, 메시지 배달이 시작되고 is_broker_enabled 카탈로그 뷰에서 sys.databases가 True로 설정됩니다. 데이터베이스에는 기존 Service Broker 식별자가 유지됩니다.

NEW_BROKER

service_broker_guid 및 복원된 데이터베이스 모두에서 새 sys.databases 값을 만듭니다. 정리를 사용하여 모든 대화 엔드포인트를 종료합니다. 이때 Service Broker가 설정되지만 원격 대화 엔드포인트에 메시지가 전송되지 않습니다. 이전 Service Broker 식별자를 참조하는 경로는 새 식별자로 다시 만들어야 합니다.

ERROR_BROKER_CONVERSATIONS

데이터베이스가 연결 또는 복원되었다는 오류 메시지를 표시하고 모든 대화를 끝냅니다. Service Broker는 이 작업이 완료될 때까지 해제된 후 설정됩니다. 데이터베이스에는 기존 Service Broker 식별자가 유지됩니다.

분리되는 대신 복사된 복제된 데이터베이스를 연결하는 경우 다음을 고려합니다.

  • 데이터베이스를 원래 데이터베이스와 동일한 서버 인스턴스 및 버전에 연결하는 경우에는 추가 작업이 필요하지 않습니다.
  • 데이터베이스를 동일한 서버 인스턴스의 업그레이드된 버전에 연결하는 경우에는 연결 작업이 완료된 다음, sp_vupgrade_replication을 실행하여 복제를 업그레이드해야 합니다.
  • 데이터베이스를 버전에 관계없이 다른 서버 인스턴스에 연결하는 경우에는 연결 작업이 완료된 다음, sp_removedbreplication을 실행하여 복제를 제거해야 합니다.

참고

연결은 vardecimal 스토리지 형식에서 작동하지만 SQL Server 데이터베이스 엔진을 최소 SQL Server 2005(9.x) SP2로 업그레이드해야 합니다. vardecimal 스토리지 형식을 사용하는 데이터베이스는 이전 버전의 SQL Server에 연결할 수 없습니다. vardecimal 스토리지 형식에 대한 자세한 내용은 Data Compression을 참조하십시오.

데이터베이스가 새 SQL Server인스턴스로 처음으로 연결되거나 복원될 때 데이터베이스 마스터 키(서비스 마스터 키로 암호화됨)의 복사본은 서버에 아직 저장되지 않은 상태입니다. 데이터베이스 마스터 키를 암호 해독하려면 OPEN MASTER KEY 문을 사용해야 합니다. DMK를 암호 해독한 후에는 ALTER MASTER KEY REGENERATE 문을 사용하여 SMK(서비스 마스터 키)로 암호화된 DMK의 복사본을 서버에 프로비전함으로써 앞으로 자동 암호 해독을 사용하도록 설정할 수 있습니다. 데이터베이스가 이전 버전에서 업그레이드되지 않은 경우에는 DMK를 다시 생성해야 최신 AES 알고리즘을 사용할 수 있습니다. DMK를 다시 생성하는 방법은 ALTER MASTER KEY를 참조하세요. AES로 업그레이드하기 위해 DMK 키를 다시 생성하는 데 소요되는 시간은 DMK에서 보호하는 개체 수에 따라 달라집니다. AES로 업그레이드하기 위해 DMK 키를 다시 생성하는 것은 한 번만 필요하며 키 회전 전략의 일부로 향후 다시 생성에는 영향을 주지 않습니다. 연결을 사용하여 데이터베이스를 업그레이드하는 방법은 분리 및 연결을 사용하여 데이터베이스 업그레이드를 참조하세요.

중요

출처를 알 수 없거나 신뢰할 수 없는 데이터베이스는 연결하지 않는 것이 좋습니다. 이러한 데이터베이스에 포함된 악성 코드가 의도하지 않은 Transact-SQL 코드를 실행하거나 스키마 또는 물리적 데이터베이스 구조를 수정하여 오류가 발생할 수 있습니다. 알 수 없거나 신뢰할 수 없는 소스의 데이터베이스를 사용하기 전에 비프로덕션 서버의 데이터베이스에서 DBCC CHECKDB를 실행하여 데이터베이스에서 코드(예: 저장 프로시저 또는 다른 사용자 정의 코드)를 시험해 보세요.

참고

데이터베이스를 연결할 때 TRUSTWORTHYDB_CHAINING 옵션은 영향도 주지 않습니다.

FOR ATTACH_REBUILD_LOG

기존 운영 체제 파일 집합을 연결하여 데이터베이스를 만들도록 지정합니다. 이 옵션은 읽기/쓰기 데이터베이스로 제한됩니다. 주 파일을 지정하는 <filespec> 항목이 있어야 합니다. 하나 이상의 트랜잭션 로그 파일이 없으면 로그 파일이 다시 작성됩니다. ATTACH_REBUILD_LOG는 1MB의 새 로그 파일을 자동으로 만들어 이 파일은 기본 로그 파일 위치에 저장됩니다. 이 위치에 대한 자세한 내용은 SSMS에서 데이터 및 로그 파일의 기본 위치 보기 또는 변경을 참조하세요.

참고

로그 파일이 있으면 데이터베이스 엔진이 로그 파일을 다시 작성하지 않고 해당 파일을 사용합니다.

FOR ATTACH_REBUILD_LOG를 사용하려면 다음과 같은 조건을 충족해야 합니다.

  • 데이터베이스가 완전하게 종료된 상태여야 합니다.
  • 모든 데이터 파일(MDF 및 NDF)을 사용할 수 있어야 합니다.

중요

이 작업을 실행하면 로그 백업 체인이 끊어집니다. 따라서 작업이 완료된 후 전체 데이터베이스 백업을 수행하는 것이 좋습니다. 자세한 내용은 BACKUP을 참조하세요.

일반적으로 FOR ATTACH_REBUILD_LOG는 로그 크기가 큰 읽기/쓰기 데이터베이스를 복사본이 주로 읽기 작업에만 사용되어 원본 데이터베이스에 비해 로그 공간이 덜 필요한 다른 서버에 복사할 때 사용됩니다.

데이터베이스 스냅샷에는 FOR ATTACH_REBUILD_LOG를 지정할 수 없습니다.

데이터베이스를 연결 및 분리하는 방법은 데이터베이스 분리 및 연결을 참조하세요.

<filespec>

파일 속성을 제어합니다.

NAME logical_file_name

파일의 논리적 이름을 지정합니다. FOR ATTACH 절 중 하나를 지정하는 경우가 아니면 FILENAME이 지정될 때 NAME이 필요합니다. FILESTREAM 파일 그룹 이름은 PRIMARY로 지정할 수 없습니다.

logical_file_name

파일을 참조할 때 SQL Server에서 사용되는 논리적 이름입니다. Logical_file_name은 데이터베이스에서 고유해야 하며 식별자에 대한 규칙을 따라야 합니다. 이 이름은 문자 상수, 유니코드 상수, 일반 식별자 또는 구분 식별자가 될 수 있습니다.

FILENAME { 'os_file_name' | 'filestream_path' }

운영 체제(물리적) 파일 이름을 지정합니다.

'os_file_name'

파일을 만들 때 운영 체제에서 사용하는 경로 및 파일 이름입니다. 파일은 SQL Server가 설치된 로컬 서버, SAN(스토리지 영역 네트워크) 또는 iSCSI 기반 네트워크 중 하나의 디바이스에 있어야 합니다. 지정한 경로는 CREATE DATABASE 문을 실행하기 전에 반드시 존재해야 합니다. 자세한 내용은 이 문서의 후반부에 있는 데이터베이스 파일 및 파일 그룹을 참조하세요.

파일에 UNC 경로가 지정되면 SIZE, MAXSIZE 및 FILEGROWTH 매개 변수를 설정할 수 있습니다.

파일이 원시 파티션에 있는 경우 os_file_name은 기존 원시 파티션의 드라이브 문자만 지정해야 합니다. 각 원시 파티션에는 데이터 파일을 하나만 만들 수 있습니다.

참고

원시 파티션은 SQL Server 2014 이상 버전에서는 지원되지 않습니다.

파일이 읽기 전용 보조 파일이 아니거나 데이터베이스가 읽기 전용이 아니면 데이터 파일을 압축 파일 시스템에 저장하지 마십시오. 또한 로그 파일을 압축 파일 시스템에 저장하면 안 됩니다.

'filestream_path'

FILESTREAM 파일 그룹의 경우 FILENAME은 FILESTREAM 데이터가 저장되는 경로를 나타냅니다. 따라서 마지막 폴더 바로 위의 경로까지 있어야 하고 마지막 폴더 자체는 있으면 안 됩니다. 예를 들어 C:\MyFiles\MyFilestreamData 경로를 지정하는 경우 ALTER DATABASE를 실행하기 전에 C:\MyFiles 경로가 있어야 하지만 MyFilestreamData 폴더는 있으면 안 됩니다.

파일 그룹과 파일(<filespec>)은 같은 문으로 만들어야 합니다.

SIZE 및 FILEGROWTH 속성은 FILESTREAM 파일 그룹에 적용되지 않습니다.

SIZE size

파일의 크기를 지정합니다.

os_file_name이 UNC 경로로 지정된 경우에는 SIZE를 지정할 수 없습니다. SIZE는 FILESTREAM 파일 그룹에 적용되지 않습니다.

size

파일의 처음 크기입니다.

기본 파일에 대해 size를 지정하지 않으면 데이터베이스 엔진은 model 데이터베이스의 기본 파일 크기를 사용합니다. model 데이터베이스의 기본 크기는 8MB(SQL Server 2016(13.x)부터) 또는 1MB(이전 버전)입니다. 보조 데이터 파일 또는 로그 파일을 지정하고 해당 파일의 size를 지정하지 않으면 데이터베이스 엔진에서 파일 크기를 8MB(SQL Server 2016(13.x)부터) 또는 1MB(이전 버전)로 지정합니다. 주 파일에 지정된 크기는 최소한 model 데이터베이스의 주 파일 크기와 같아야 합니다.

KB(킬로바이트), MB(메가바이트), GB(기가바이트) 또는 TB(테라바이트) 접미사를 사용할 수 있습니다. 기본값은 MB입니다. 정수를 지정합니다. 10진수는 포함하지 마세요. Size는 정수 값입니다. 2147483647보다 큰 값에는 더 큰 단위를 사용합니다.

MAXSIZE max_size

파일이 증가할 수 있는 최대 크기를 지정합니다. os_file_name이 UNC 경로로 지정된 경우에는 MAXSIZE를 지정할 수 없습니다.

max_size

최대 파일 크기입니다. KB, MB, GB 및 TB 접미사를 사용할 수 있습니다. 기본값은 MB입니다. 정수를 지정합니다. 10진수는 포함하지 마세요. max_size를 지정하지 않으면 디스크가 꽉 찰 때까지 파일이 커집니다. Max_size는 정수 값입니다. 2147483647보다 큰 값에는 더 큰 단위를 사용합니다.

무제한

디스크가 가득 찼을 때까지 파일이 커지게 지정합니다. SQL Server에서 무제한 증가로 지정된 로그 파일의 최대 크기는 2TB이고 데이터 파일의 최대 크기는 16TB입니다.

참고

이 옵션이 FILESTREAM 컨테이너에 지정되면 최대 크기가 없습니다. 디스크가 꽉 찰 때까지 파일이 증가합니다.

FILEGROWTH growth_increment

파일의 자동 증분을 지정합니다. 파일의 FILEGROWTH 설정은 MAXSIZE 설정을 초과할 수 없습니다. os_file_name이 UNC 경로로 지정된 경우에는 FILEGROWTH를 지정할 수 없습니다. FILEGROWTH는 FILESTREAM 파일 그룹에 적용되지 않습니다.

growth_increment

새 공간이 필요할 때마다 파일에 추가되는 공간의 양입니다.

이 값은 MB, KB, GB, TB 또는 %(퍼센트) 단위로 지정할 수 있습니다. MB, KB 또는 % 접미사를 붙이지 않고 숫자를 지정하면 MB가 기본값이 됩니다. %가 지정되면 증분 크기는 파일 크기 증가가 발생하는 시점에서 해당 파일 크기에 대한 특정 비율입니다. 지정한 크기는 64KB 단위로 반올림되며 최소 값은 64KB입니다.

값이 0이면 자동 증가가 해제되어 있고 추가 공간이 허용되지 않음을 나타냅니다.

FILEGROWTH를 지정하지 않은 경우 기본값은 다음과 같습니다.

버전 기본값
SQL Server 2016(13.x)부터 데이터는 64MB입니다. 로그 파일은 64MB입니다.
SQL Server 2005(9.x)부터 데이터는 1MB입니다. 로그 파일은 10%입니다.
SQL Server 2005(9.x) 이전 데이터는 10%입니다. 로그 파일은 10%입니다.

<filegroup>

파일 그룹 속성을 제어합니다. 데이터베이스 스냅샷에는 파일 그룹을 지정할 수 없습니다.

FILEGROUP filegroup_name

파일 그룹의 논리적 이름입니다.

filegroup_name

filegroup_name 데이터베이스에서 고유해야 하며 시스템 제공 이름 PRIMARY 및 PRIMARY_LOG 수 없습니다. 이 이름은 문자 상수, 유니코드 상수, 일반 식별자 또는 구분 식별자가 될 수 있습니다. 이 이름은 식별자에 대한 규칙을 따라야 합니다.

CONTAINS FILESTREAM

파일 그룹이 FILESTREAM BLOB(Binary Large Objects)을 파일 시스템에 저장되도록 지정합니다.

DEFAULT

명명한 파일 그룹이 데이터베이스의 기본 파일 그룹임을 지정합니다.

CONTAINS MEMORY_OPTIMIZED_DATA

적용 대상: SQL Server 2014(12.x) 이상

파일 그룹이 memory_optimized 데이터를 파일 시스템에 저장하도록 지정합니다. 자세한 내용은 메모리 내 최적화 개요 및 사용 시나리오를 참조하세요. 데이터베이스당 MEMORY_OPTIMIZED_DATA 파일 그룹이 하나만 허용됩니다. 메모리 최적화 데이터를 저장하기 위해 파일 그룹을 만드는 코드 샘플은 메모리 최적화 테이블 및 고유하게 컴파일된 저장 프로시저 만들기를 참조하세요.

database_snapshot_name

새 데이터베이스 스냅샷의 이름입니다. 데이터베이스 스냅샷 이름은 SQL Server 인스턴스 내에서 고유해야 하며 식별자에 대한 규칙을 따라야 합니다. database_snapshot_name은 최대 128자까지 가능합니다.

ON ( NAME =logical_file_name, FILENAME ='os_file_name') [ ,... n ]

데이터베이스 스냅샷을 만들기 위해 원본 데이터베이스의 파일 목록을 지정합니다. 스냅샷이 동작하려면 모든 데이터 파일을 개별적으로 지정해야 합니다. 그러나 데이터베이스 스냅샷에는 로그 파일이 허용되지 않습니다. FILESTREAM 파일 그룹은 데이터베이스 스냅샷에서 지원되지 않습니다. FILESTREAM 데이터 파일이 CREATE DATABASE ON 절에 포함되어 있으면 문이 실패하고 오류가 발생합니다.

NAME, FILENAME 및 각 값에 대한 내용은 해당하는 <filespec> 값의 설명을 참조하세요.

참고

데이터베이스 스냅샷을 만들 때는 다른 <filespec> 옵션 및 PRIMARY 키워드를 사용할 수 없습니다.

AS SNAPSHOT OF source_database_name

만들고 있는 데이터베이스가 source_database_name에 지정된 원본 데이터베이스의 데이터베이스 스냅샷임을 지정합니다. 스냅샷 및 원본 데이터베이스는 같은 인스턴스에 있어야 합니다.

SQL Server 2019 이전에는 데이터베이스 스냅샷의 원본 데이터베이스에 MEMORY_OPTIMIZED_DATA 파일 그룹을 포함할 수 없었습니다. 메모리 내 데이터베이스 스냅샷에 대한 지원이 SQL Server 2019에 추가되었습니다.

자세한 내용은 데이터베이스 스냅샷을 참조하세요.

설명

사용자 데이터베이스를 생성, 수정 또는 삭제할 때마다 마스터 데이터베이스를 백업해야 합니다.

CREATE DATABASE 문은 자동 커밋 모드(기본 트랜잭션 관리 모드)에서 실행되어야 하며 명시적 또는 암시적 트랜잭션에서는 허용되지 않습니다.

CREATE DATABASE 문 하나를 사용하여 데이터베이스 및 해당 데이터베이스를 저장하는 파일을 만들 수 있습니다. SQL Server에서는 다음과 같은 단계로 CREATE DATABASE 문을 구현합니다.

  1. SQL Server에서 model 데이터베이스의 복사본을 사용하여 데이터베이스 및 해당 메타데이터를 초기화합니다.
  2. 데이터베이스에 Service Broker GUID가 할당됩니다.
  3. 데이터베이스 엔진에서 데이터베이스 내의 공간 사용 방법을 기록하는 내부 데이터가 포함된 페이지를 제외하고 데이터베이스의 나머지 부분을 빈 페이지로 채웁니다.

하나의 SQL Server인스턴스당 최대 32,767개의 데이터베이스를 지정할 수 있습니다.

각 데이터베이스에는 해당 데이터베이스에서 특수한 작업을 수행할 수 있는 소유자가 있습니다. 소유자는 데이터베이스를 만든 사용자입니다. ALTER AUTHORIZATION를 사용하여 데이터베이스 소유자를 변경할 수 있습니다.

일부 데이터베이스 기능은 파일 시스템의 기능이 있어야 데이터베이스의 모든 기능을 사용할 수 있습니다. 파일 시스템 기능 집합이 필요한 일부 기능의 예를 들면 다음과 같습니다.

  • DBCC CHECKDB
  • FileStream
  • VSS 및 파일 스냅샷을 이용한 온라인 백업
  • 데이터베이스 스냅샷 생성
  • 메모리 최적화 데이터 파일 그룹

데이터베이스 파일 및 파일 그룹

모든 데이터베이스에는 주 파일트랜잭션 로그 파일이라는 2개의 파일과 하나 이상의 파일 그룹이 있습니다. 각 데이터베이스에 최대 32,767개의 파일과 32,767개의 파일 그룹을 지정할 수 있습니다.

데이터베이스를 만들 때는 데이터베이스에서 예상되는 최대 데이터 크기를 고려하여 데이터 파일을 가능한 한 크게 만드는 것이 좋습니다.

SQL Server의 성능과 안정성을 최적화하는 구성을 위해 SAN(스토리지 영역 네트워크), iSCSI 기반 네트워크 또는 로컬로 연결된 디스크에 SQL Server 데이터베이스 파일을 스토리지하는 것이 좋습니다.

데이터베이스 스냅샷

CREATE DATABASE 문을 사용하여 원본 데이터베이스의 읽기 전용 정적 뷰인 데이터베이스 스냅샷을 만들 수 있습니다. 데이터베이스 스냅샷은 스냅샷을 만들었을 당시의 원본 데이터베이스와 트랜잭션 측면에서 일관성을 가집니다. 원본 데이터베이스 하나에 스냅샷이 여러 개 있을 수 있습니다.

참고

데이터베이스 스냅샷을 만드는 경우 CREATE DATABASE 문은 로그 파일, 오프라인 파일, 복원 파일 및 존재하지 않는 파일을 참조할 수 없습니다.

데이터베이스 스냅샷 만들기에 실패한 경우 해당 스냅샷은 주의 대상이 되며 삭제해야 합니다. 자세한 내용은 DROP DATABASE를 참조하세요.

각 스냅샷은 DROP DATABASE를 사용하여 삭제할 때까지 그대로 유지됩니다.

자세한 내용은 데이터베이스 스냅샷 및데이터베이스 스냅샷 만들기(Transact-SQL)를 참조하세요.

데이터베이스 옵션

데이터베이스를 만들 때마다 몇 가지 데이터베이스 옵션이 자동으로 설정됩니다. 이러한 옵션에 대한 자세한 내용은 ALTER DATABASE SET 옵션을 참조하세요.

모델 데이터베이스 및 새 데이터베이스 만들기

model 데이터베이스에 있는 모든 사용자 정의 개체는 새로 만든 데이터베이스에 복사됩니다. 테이블, 뷰, 저장 프로시저, 데이터 형식 등의 모든 개체를 model 데이터베이스에 추가하여 새로 만든 모든 데이터베이스에 포함할 수 있습니다.

크기 매개 변수를 추가하지 않고 CREATE DATABASE <database_name> 문을 지정하면 model 데이터베이스의 주 파일과 크기가 같은 주 데이터 파일이 만들어집니다.

FOR ATTACH를 지정하지 않은 경우 모든 새 데이터베이스는 model 데이터베이스에서 데이터베이스 옵션 설정을 상속합니다. 예를 들어 자동 축소와 같은 데이터베이스 옵션은 데이터베이스와 새로 만드는 모든 데이터베이스에서 model로 설정됩니다. model 데이터베이스에서 옵션을 변경하면 새로 만드는 모든 데이터베이스에 이러한 새 옵션 설정이 사용됩니다. 기존 데이터베이스는 model 데이터베이스 변경 작업에 영향을 받지 않습니다. CREATE DATABASE 문에 FOR ATTACH를 지정하는 경우 새 데이터베이스는 원본 데이터베이스의 데이터베이스 옵션 설정을 상속합니다.

데이터베이스 정보 보기

카탈로그 뷰, 시스템 함수 및 시스템 저장 프로시저를 사용하여 데이터베이스, 파일 및 파일 그룹에 대한 정보를 반환할 수 있습니다. 자세한 내용은 시스템 뷰를 참조하세요.

사용 권한

CREATE DATABASE, CREATE ANY DATABASE 또는 ALTER ANY DATABASE 권한이 필요합니다.

SQL Server 인스턴스에서 디스크 사용을 제어하기 위해 데이터베이스를 만들 수 있는 권한은 일반적으로 몇 개의 로그인으로 제한됩니다.

다음 예제에서는 데이터베이스 사용자에게 Fay데이터베이스를 만들 수 있는 권한을 제공합니다.

USE master;
GO
GRANT CREATE DATABASE TO [Fay];
GO

데이터 및 로그 파일에 대한 사용 권한

SQL Server에서는 각 데이터베이스의 데이터 및 로그 파일에 특정 사용 권한이 설정됩니다. 데이터베이스에 다음 작업이 적용될 때마다 다음과 같은 사용 권한이 설정됩니다.

  • 연결
  • 백업
  • 생성일
  • 분리
  • 새 파일을 추가하기 위해 수정됨
  • 복원

이러한 사용 권한을 설정하면 누구나 액세스할 수 있는 디렉터리에 있는 파일이 실수로 변경되는 것을 방지할 수 있습니다.

참고

Microsoft SQL Server 2005 Express Edition은 데이터 및 로그 파일 권한을 설정하지 않습니다.

예제

A. 파일을 지정하지 않고 데이터베이스 만들기

다음 예에서는 mytest 데이터베이스를 만들고 해당 주 파일 및 트랜잭션 로그 파일을 만듭니다. 문에 <filespec> 항목이 없으므로 주 데이터베이스 파일의 크기는 model 데이터베이스 주 파일의 크기와 같습니다. 트랜잭션 로그는 512KB와 주 데이터 파일 크기의 25% 중 더 큰 값으로 설정됩니다. MAXSIZE를 지정하지 않았으므로 사용 가능한 디스크 공간을 모두 채울 때까지 파일 크기가 증가할 수 있습니다. 이 예에서는 mytest 데이터베이스를 만들기 전에 mytest라는 데이터베이스(있는 경우)를 삭제하는 방법도 보여 줍니다.

USE master;
GO
IF DB_ID (N'mytest') IS NOT NULL
DROP DATABASE mytest;
GO
CREATE DATABASE mytest;
GO
-- Verify the database files and sizes
SELECT name, size, size*1.0/128 AS [Size in MBs]
FROM sys.master_files
WHERE name = N'mytest';
GO

B. 데이터 파일 및 트랜잭션 로그 파일을 지정하는 데이터베이스 만들기

다음 예에서는 Sales 데이터베이스를 만듭니다. 주 키워드를 사용하지 않았으므로 첫 번째 파일(Sales_dat)이 주 파일이 됩니다. Sales_dat 파일의 SIZE 매개 변수에 MB 또는 KB를 지정하지 않았으므로 기본값 MB를 사용하여 할당됩니다. 사용자 데이터베이스를 생성, 수정 또는 삭제할 때마다 Sales_log 파일은 MB 매개 변수에 명시적으로 SIZE 접미사를 지정했으므로 메가바이트(MB)로 공간이 할당됩니다.

USE master;
GO
CREATE DATABASE Sales
ON
( NAME = Sales_dat,
    FILENAME = 'C:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\DATA\saledat.mdf',
    SIZE = 10,
    MAXSIZE = 50,
    FILEGROWTH = 5 )
LOG ON
( NAME = Sales_log,
    FILENAME = 'C:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\DATA\salelog.ldf',
    SIZE = 5MB,
    MAXSIZE = 25MB,
    FILEGROWTH = 5MB ) ;
GO

C. 데이터 파일 및 트랜잭션 로그 파일을 여러 개 지정하여 데이터베이스 만들기

다음 예에서는 3개의 Archive 데이터 파일과 2개의 100-MB 트랜잭션 로그 파일을 가진 100-MB 데이터베이스를 만듭니다. 주 파일은 목록의 첫 번째 파일이며 PRIMARY 키워드로 명시적으로 지정되어 있습니다. 트랜잭션 로그 파일은 LOG ON 키워드 다음에 지정됩니다. FILENAME 옵션에서 파일에 사용된 확장명에 유의하십시오. 주 데이터 파일에는 .mdf, 보조 데이터 파일에는 .ndf, 트랜잭션 로그 파일에는 .ldf가 각각 사용됩니다. 이 예에서는 데이터베이스를 D: 데이터베이스와 함께 배치하는 대신 master 드라이브에 배치합니다.

USE master;
GO
CREATE DATABASE Archive
ON
PRIMARY
    (NAME = Arch1,
    FILENAME = 'D:\SalesData\archdat1.mdf',
    SIZE = 100MB,
    MAXSIZE = 200,
    FILEGROWTH = 20),
    ( NAME = Arch2,
    FILENAME = 'D:\SalesData\archdat2.ndf',
    SIZE = 100MB,
    MAXSIZE = 200,
    FILEGROWTH = 20),
    ( NAME = Arch3,
    FILENAME = 'D:\SalesData\archdat3.ndf',
    SIZE = 100MB,
    MAXSIZE = 200,
    FILEGROWTH = 20)
LOG ON
  (NAME = Archlog1,
    FILENAME = 'D:\SalesData\archlog1.ldf',
    SIZE = 100MB,
    MAXSIZE = 200,
    FILEGROWTH = 20),
  (NAME = Archlog2,
    FILENAME = 'D:\SalesData\archlog2.ldf',
    SIZE = 100MB,
    MAXSIZE = 200,
    FILEGROWTH = 20) ;
GO

D. 파일 그룹이 있는 데이터베이스 만들기

다음 예에서는 아래에 나열된 파일 그룹을 포함하는 Sales 데이터베이스를 만듭니다.

  • Spri1_datSpri2_dat 파일을 포함하는 주 파일 그룹. 이러한 파일의 FILEGROWTH 증가분은 15%로 지정됩니다.
  • SalesGroup1SGrp1Fi1 파일을 포함하는 SGrp1Fi2 파일 그룹
  • SalesGroup2SGrp2Fi1 파일을 포함하는 SGrp2Fi2 파일 그룹

이 예에서는 성능을 향상시키기 위해 데이터 파일과 로그 파일을 서로 다른 디스크에 배치합니다.

USE master;
GO
CREATE DATABASE Sales
ON PRIMARY
( NAME = SPri1_dat,
    FILENAME = 'D:\SalesData\SPri1dat.mdf',
    SIZE = 10,
    MAXSIZE = 50,
    FILEGROWTH = 15% ),
( NAME = SPri2_dat,
    FILENAME = 'D:\SalesData\SPri2dt.ndf',
    SIZE = 10,
    MAXSIZE = 50,
    FILEGROWTH = 15% ),
FILEGROUP SalesGroup1
( NAME = SGrp1Fi1_dat,
    FILENAME = 'D:\SalesData\SG1Fi1dt.ndf',
    SIZE = 10,
    MAXSIZE = 50,
    FILEGROWTH = 5 ),
( NAME = SGrp1Fi2_dat,
    FILENAME = 'D:\SalesData\SG1Fi2dt.ndf',
    SIZE = 10,
    MAXSIZE = 50,
    FILEGROWTH = 5 ),
FILEGROUP SalesGroup2
( NAME = SGrp2Fi1_dat,
    FILENAME = 'D:\SalesData\SG2Fi1dt.ndf',
    SIZE = 10,
    MAXSIZE = 50,
    FILEGROWTH = 5 ),
( NAME = SGrp2Fi2_dat,
    FILENAME = 'D:\SalesData\SG2Fi2dt.ndf',
    SIZE = 10,
    MAXSIZE = 50,
    FILEGROWTH = 5 )
LOG ON
( NAME = Sales_log,
    FILENAME = 'E:\SalesLog\salelog.ldf',
    SIZE = 5MB,
    MAXSIZE = 25MB,
    FILEGROWTH = 5MB ) ;
GO

E. 데이터베이스 연결

다음 예에서는 예 4에서 만든 Archive 데이터베이스를 분리한 다음, FOR ATTACH 절을 사용하여 데이터베이스를 연결합니다. Archive는 데이터 파일과 로그 파일을 여러 개 포함하도록 정의되었습니다. 그러나 파일을 만든 후 위치를 변경하지 않았으므로 FOR ATTACH 절에 주 파일만 지정해야 합니다. SQL Server 2005(9.x)부터는 연결 중인 데이터베이스에 속한 모든 전체 텍스트 파일이 데이터베이스에 연결됩니다.

USE master;
GO
sp_detach_db Archive;
GO
CREATE DATABASE Archive
  ON (FILENAME = 'D:\SalesData\archdat1.mdf')
  FOR ATTACH ;
GO

F. 데이터베이스 스냅샷 만들기

다음 예에서는 sales_snapshot0600 데이터베이스 스냅샷을 만듭니다. 데이터베이스 스냅샷은 읽기 전용이므로 로그 파일을 지정할 수 없습니다. 구문에 맞게 원본 데이터베이스의 모든 파일을 지정하며 파일 그룹은 지정하지 않습니다.

이 예의 원본 데이터베이스는 예 4에서 만든 Sales 데이터베이스입니다.

USE master;
GO
CREATE DATABASE sales_snapshot0600 ON
    ( NAME = SPri1_dat, FILENAME = 'D:\SalesData\SPri1dat_0600.ss'),
    ( NAME = SPri2_dat, FILENAME = 'D:\SalesData\SPri2dt_0600.ss'),
    ( NAME = SGrp1Fi1_dat, FILENAME = 'D:\SalesData\SG1Fi1dt_0600.ss'),
    ( NAME = SGrp1Fi2_dat, FILENAME = 'D:\SalesData\SG1Fi2dt_0600.ss'),
    ( NAME = SGrp2Fi1_dat, FILENAME = 'D:\SalesData\SG2Fi1dt_0600.ss'),
    ( NAME = SGrp2Fi2_dat, FILENAME = 'D:\SalesData\SG2Fi2dt_0600.ss')
AS SNAPSHOT OF Sales ;
GO

G. 데이터베이스 만들기 및 데이터 정렬 이름과 옵션 지정

다음 예에서는 MyOptionsTest 데이터베이스를 만듭니다. 데이터 정렬 이름을 지정하고 TRUSTYWORTHYDB_CHAINING 옵션을 ON으로 설정합니다.

USE master;
GO
IF DB_ID (N'MyOptionsTest') IS NOT NULL
DROP DATABASE MyOptionsTest;
GO
CREATE DATABASE MyOptionsTest
COLLATE French_CI_AI
WITH TRUSTWORTHY ON, DB_CHAINING ON;
GO
--Verifying collation and option settings.
SELECT name, collation_name, is_trustworthy_on, is_db_chaining_on
FROM sys.databases
WHERE name = N'MyOptionsTest';
GO

H. 이동된 전체 텍스트 카탈로그 연결

다음 예에서는 AdvWksFtCat 전체 텍스트 카탈로그를 AdventureWorks2022 데이터 및 로그 파일과 연결합니다. 이 예에서는 전체 텍스트 카탈로그를 기본 위치에서 새 위치 c:\myFTCatalogs로 이동하고 데이터 및 로그 파일은 기본 위치에 그대로 남아 있습니다.

USE master;
GO
--Detach the AdventureWorks2022 database
sp_detach_db AdventureWorks2022;
GO
-- Physically move the full text catalog to the new location.
--Attach the AdventureWorks2022 database and specify the new location of the full-text catalog.
CREATE DATABASE AdventureWorks2022 ON
    (FILENAME = 'c:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\Data\AdventureWorks2022_data.mdf'),
    (FILENAME = 'c:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\Data\AdventureWorks2022_log.ldf'),
    (FILENAME = 'c:\myFTCatalogs\AdvWksFtCat')
FOR ATTACH;
GO

9\. 행 파일 그룹 하나와 FILESTREAM 파일 그룹 두 개를 지정하는 데이터베이스 만들기

다음 예에서는 FileStreamDB 데이터베이스를 만듭니다. 이 데이터베이스에는 행 파일 그룹 하나와 FILESTREAM 파일 그룹 두 개가 있습니다. 각 파일 그룹에는 다음과 같이 하나의 파일이 포함됩니다.

  • FileStreamDB_data는 행 데이터를 포함합니다. 여기에는 기본 경로가 지정된 FileStreamDB_data.mdf 파일 하나가 포함됩니다.
  • FileStreamPhotos는 FILESTREAM 데이터를 포함합니다. 여기에는 두 개의 FILESTREAM 데이터 컨테이너가 포함됩니다. 하나는 FSPhotos에 있는 C:\MyFSfolder\Photos이고 다른 하나는 FSPhotos2에 있는 D:\MyFSfolder\Photos입니다. 이 그룹은 기본 FILESTREAM 파일 그룹으로 표시됩니다.
  • FileStreamResumes는 FILESTREAM 데이터를 포함합니다. 여기에는 FSResumes에 있는 FILESTREAM 데이터 컨테이너 C:\MyFSfolder\Resumes가 포함됩니다.
USE master;
GO
-- Get the SQL Server data path.
DECLARE @data_path nvarchar(256);
SET @data_path = (SELECT SUBSTRING(physical_name, 1, CHARINDEX(N'master.mdf', LOWER(physical_name)) - 1)
      FROM master.sys.master_files
      WHERE database_id = 1 AND file_id = 1);

 -- Execute the CREATE DATABASE statement.
EXECUTE ('CREATE DATABASE FileStreamDB
ON PRIMARY
    (
    NAME = FileStreamDB_data
    ,FILENAME = ''' + @data_path + 'FileStreamDB_data.mdf''
    ,SIZE = 10MB
    ,MAXSIZE = 50MB
    ,FILEGROWTH = 15%
    ),
FILEGROUP FileStreamPhotos CONTAINS FILESTREAM DEFAULT
    (
    NAME = FSPhotos
    ,FILENAME = ''C:\MyFSfolder\Photos''
-- SIZE and FILEGROWTH should not be specified here.
-- If they are specified an error will be raised.
, MAXSIZE = 5000 MB
    ),
    (
      NAME = FSPhotos2
      , FILENAME = ''D:\MyFSfolder\Photos''
      , MAXSIZE = 10000 MB
     ),
FILEGROUP FileStreamResumes CONTAINS FILESTREAM
    (
    NAME = FileStreamResumes
    ,FILENAME = ''C:\MyFSfolder\Resumes''
    )
LOG ON
    (
    NAME = FileStream_log
    ,FILENAME = ''' + @data_path + 'FileStreamDB_log.ldf''
    ,SIZE = 5MB
    ,MAXSIZE = 25MB
    ,FILEGROWTH = 5MB
    )'
);
GO

J. 여러 파일이 포함된 FILESTREAM 파일 그룹이 있는 데이터베이스 만들기

다음 예에서는 BlobStore1 데이터베이스를 만듭니다. 이 데이터베이스에는 행 파일 그룹 하나와 FILESTREAM 파일 그룹 하나(FS)가 있습니다. FILESTREAM 파일 그룹에는 두 개의 파일(FS1FS2)이 포함됩니다. 그런 다음 세 번째 파일(FS3)을 FILESTREAM 파일 그룹에 추가하여 데이터베이스를 변경합니다.

USE master;
GO

CREATE DATABASE [BlobStore1]
CONTAINMENT = NONE
ON PRIMARY
(
    NAME = N'BlobStore1',
    FILENAME = N'C:\BlobStore\BlobStore1.mdf',
    SIZE = 100MB,
    MAXSIZE = UNLIMITED,
    FILEGROWTH = 1MB
),
FILEGROUP [FS] CONTAINS FILESTREAM DEFAULT
(  
    NAME = N'FS1',
    FILENAME = N'C:\BlobStore\FS1',
    MAXSIZE = UNLIMITED
),
(
    NAME = N'FS2',
    FILENAME = N'C:\BlobStore\FS2',
    MAXSIZE = 100MB
)
LOG ON
(
    NAME = N'BlobStore1_log',
    FILENAME = N'C:\BlobStore\BlobStore1_log.ldf',
    SIZE = 100MB,
    MAXSIZE = 1GB,
    FILEGROWTH = 1MB
);
GO

ALTER DATABASE [BlobStore1]
ADD FILE
(
    NAME = N'FS3',
    FILENAME = N'C:\BlobStore\FS3',
    MAXSIZE = 100MB
)
TO FILEGROUP [FS];
GO

* SQL Database *

 

SQL Database

개요

Azure SQL Database에서 이 문은 Azure SQL Server와 함께 사용하여 단일 데이터베이스 또는 탄력적 풀의 데이터베이스를 만들 수 있습니다. 이 문을 사용하여 데이터베이스 이름, 데이터 정렬, 최대 크기, 버전, 서비스 목표 및 새 데이터베이스의 탄력적 풀(해당하는 경우)을 지정합니다. 탄력적 풀에서 데이터베이스를 만드는 데 사용할 수도 있습니다. 또한 다른 SQL Database 서버에서 데이터베이스 복사본을 만드는 데 사용할 수 있습니다.

구문

데이터베이스 만들기

구문 표기 규칙에 대한 자세한 내용은 Transact-SQL 구문 표기 규칙을 참조하세요.

CREATE DATABASE database_name [ COLLATE collation_name ]
{
  (<edition_options> [, ...n])
}
[ WITH <with_options> [,..n]]
[;]

<with_options> ::=
{
    CATALOG_COLLATION = { DATABASE_DEFAULT | SQL_Latin1_General_CP1_CI_AS }
  | BACKUP_STORAGE_REDUNDANCY = { 'LOCAL' | 'ZONE' | 'GEO' | 'GEOZONE' }
  | LEDGER = {ON | OFF }
}

<edition_options> ::=
{

  MAXSIZE = { 100 MB | 500 MB | 1 ... 1024 ... 4096 GB }
  | ( EDITION = { 'Basic' | 'Standard' | 'Premium' | 'GeneralPurpose' | 'BusinessCritical' | 'Hyperscale' }
  | SERVICE_OBJECTIVE =
    { 'Basic' | 'S0' | 'S1' | 'S2' | 'S3' | 'S4'| 'S6'| 'S7'| 'S9'| 'S12'
      | 'P1' | 'P2' | 'P4'| 'P6' | 'P11' | 'P15'
      | 'BC_DC_n'
      | 'BC_Gen5_n' 
      | 'BC_M_n' 
      | 'GP_DC_n'
      | 'GP_Fsv2_n' 
      | 'GP_Gen5_n' 
      | 'GP_S_Gen5_n' 
      | 'HS_DC_n'
      | 'HS_Gen5_n'
      | 'HS_S_Gen5_n'
      | 'HS_MOPRMS_n' 
      | 'HS_PRMS_n' 
      | { ELASTIC_POOL(name = <elastic_pool_name>) } })
}

데이터베이스 복사

CREATE DATABASE database_name
    AS COPY OF [source_server_name.] source_database_name
    [ ( SERVICE_OBJECTIVE =
      { 'Basic' |'S0' | 'S1' | 'S2' | 'S3'| 'S4'| 'S6'| 'S7'| 'S9'| 'S12'
      | 'P1' | 'P2' | 'P4'| 'P6' | 'P11' | 'P15'
      | 'GP_Gen5_n'
      | 'GP_Fsv2_n'
      | 'GP_S_Gen5_n'
      | 'BC_Gen5_n'
      | 'BC_M_n'
      | 'HS_Gen5_n'
      | 'HS_S_Gen5_n'
      | 'HS_PRMS_n'
      | 'HS_MOPRMS_n'
      | { ELASTIC_POOL(name = <elastic_pool_name>) } })
   ]
   [ WITH ( BACKUP_STORAGE_REDUNDANCY = { 'LOCAL' | 'ZONE' | 'GEO' } ) ]
[;]

인수

database_name

새 데이터베이스의 이름입니다. 이 이름은 SQL Server에서 고유해야 하며 식별자에 대한 SQL Server 규칙을 따라야 합니다. 자세한 내용은 식별자를 참조하세요.

Collation_name

데이터베이스 데이터의 기본 데이터 정렬을 지정합니다. 개체 식별자와 같은 시스템 메타데이터를 지정 CATALOG_COLLATION 합니다.

데이터 정렬 이름으로는 Windows 데이터 정렬 이름 또는 SQL 데이터 정렬 이름을 사용할 수 있습니다. 지정되지 않는 경우 해당 데이터베이스가 기본 데이터 정렬 SQL_Latin1_General_CP1_CI_AS에 할당됩니다.

Windows 및 SQL 데이터 정렬 이름에 대한 자세한 내용은 COLLATE(Transact-SQL)를 참조하세요.

CATALOG_COLLATION

메타데이터 카탈로그의 기본 데이터 정렬을 지정합니다. 인수는 CATALOG_COLLATION 데이터베이스를 만드는 동안에만 사용할 수 있으며 만든 후에는 변경할 수 없습니다.

기본적으로 시스템 개체 이름에 대한 메타데이터 카탈로그는 SQL_Latin1_General_CP1_CI_AS 데이터 정렬에 정렬됩니다. CATALOG_COLLATION 지정되지 않은 경우 Azure SQL Database의 기본 설정입니다.

DATABASE_DEFAULT 시스템 뷰 및 시스템 테이블에 사용되는 메타데이터 카탈로그를 데이터베이스의 데이터 정렬과 일치하도록 정렬하도록 지정합니다. 시스템 메타데이터의 개체 식별자가 데이터와 동일한 데이터 정렬을 따르도록 하려면 데이터베이스 WITH CATALOG_COLLATION = DATABASE_DEFAULT를 만들어야 합니다.

  • 데이터 및 개체 식별자에 대해 서로 다른 데이터 정렬을 사용할 수 있습니다. 다음 예제에서는 행 데이터에 대/소문자를 구분하는 데이터 정렬을 사용하여 데이터베이스를 만들지만 개체 식별자에 대한 기본 SQL_Latin1_General_CP1_CI_AS 대/소문자를 구분하지 않는 데이터 정렬을 사용합니다.

    CREATE DATABASE [different-collations] COLLATE SQL_Latin1_General_CP1_CS_AS
    
  • 데이터와 시스템 메타데이터가 모두 동일한 데이터 정렬을 사용하려면 다음을 지정합니다 WITH CATALOG_COLLATION = DATABASE_DEFAULT. 다음 예제에서는 개체 식별자에 사용할 대/소문자 구분 데이터 정렬을 사용하여 데이터베이스를 만듭니다.

    CREATE DATABASE [same-collations] COLLATE SQL_Latin1_General_CP1_CS_AS
    WITH CATALOG_COLLATION = DATABASE_DEFAULT
    

BACKUP_STORAGE_REDUNDANCY = {'LOCAL' | 'ZONE' | 'GEO'}

데이터베이스에 대한 지정 시간 복원 및 장기 보존 백업을 복제하는 방법을 지정합니다. 지역 복원 또는 지역 중단에서 복구하는 기능은 백업 스토리지 중복을 사용하여 GEO 데이터베이스를 만든 경우에만 사용할 수 있습니다. 명시적으로 지정되지 않은 한 T-SQL로 생성된 데이터베이스는 지역 중복 백업 스토리지를 사용합니다.

T-SQL을 사용하여 데이터베이스를 만들 때 데이터 상주를 적용하려면 BACKUP_STORAGE_REDUNDANCY 매개 변수를 사용하거나 LOCAL 입력으로 사용합니다ZONE.

데이터베이스를 다른 데이터베이스 AS COPY OF의 복사본으로 만들 때 옵션을 지정하는 것이 지원되며 괄호로 래핑되어야 합니다. 예들 들어 WITH (BACKUP_STORAGE_REDUNDANCY = 'LOCAL');입니다.

LEDGER = {ON | OFF}

ON으로 설정된 경우 모든 사용자 데이터의 무결성이 보호되는 원장 데이터베이스를 만듭니다. 원장 데이터베이스에는 원장 테이블만 만들 수 있습니다. 기본값은 OFF입니다. 데이터베이스를 만든 후에는 LEDGER 옵션 값을 변경할 수 없습니다. 자세한 내용은 원장 데이터베이스 구성을 참조하세요.

MAXSIZE

데이터베이스의 최대 크기를 지정합니다. MAXSIZE는 지정된 EDITION(서비스 계층)에 대해 유효해야 합니다.

다음은 서비스 계층에 대해 지원되는 MAXSIZE 값 및 기본값(D)입니다.

참고

MAXSIZE 인수는 하이퍼스케일 서비스 계층의 단일 데이터베이스에 적용되지 않습니다. 단일 하이퍼스케일 계층 데이터베이스는 필요에 따라 최대 128TB까지 증가합니다. SQL Database 서비스는 스토리지를 자동으로 추가하므로 최대 크기를 설정할 필요가 없습니다.

SQL Database 서버의 단일 및 풀링된 데이터베이스에 대한 DTU 모델

MAXSIZE 기본 S0-S2 S3-S12 P1-P6 P11-P15
100MB
500MB
1 GB
2GB √ (D)
5GB 해당 없음
10 GB 해당 없음
20GB 해당 없음
30GB 해당 없음
40GB 해당 없음
50GB 해당 없음
100GB 해당 없음
150GB 해당 없음
200GB 해당 없음
250GB 해당 없음 √ (D) √ (D)
300GB 해당 없음 해당 없음
400GB 해당 없음 해당 없음
500GB 해당 없음 해당 없음 √ (D)
750GB 해당 없음 해당 없음
1,024GB 해당 없음 해당 없음 √ (D)
1,024GB에서 4,096GB까지 256GB* 증분 해당 없음 해당 없음 해당 없음 해당 없음

* P11 및 P15는 최대 4TB의 MAXSIZE를 허용하며 기본 크기는 1,024GB입니다. P11 및 P15는 추가 비용 없이 최대 4TB가 포함된 스토리지를 사용할 수 있습니다. 프리미엄 계층에서 1TB 초과 MAXSIZE는 현재 다음 지역에서 사용할 수 있습니다. 미국 동부2, 미국 서부, US Gov 버지니아, 서유럽, 독일 중부, 동남 아시아, 일본 동부, 오스트레일리아 동부, 캐나다 중부 및 캐나다 동부. DTU 모델의 리소스 제한에 대한 자세한 내용은 DTU 리소스 제한을 참조 하세요.

DTU 모델에 대한 MAXSIZE 값은 지정된 경우 지정된 서비스 계층에 대한 이전 표에 표시된 유효한 값이어야 합니다.

vCore 구매 모델의 최대 데이터 크기 및 tempdb 크기와 같은 제한은 단일 데이터베이스에 대한 리소스 제한 또는 탄력적 풀의 리소스 제한에 대한 문서를 참조하세요.

vCore 모델을 사용할 때 MAXSIZE 값을 설정하지 않으면 기본값은 32GB입니다. vCore 모델의 리소스 제한 사항에 대한 자세한 내용은 vCore 리소스 제한을 참조 하세요.

EDITION

데이터베이스의 서비스 계층을 지정합니다.

단일 및 풀링된 데이터베이스. 사용 가능한 값은 ‘Basic’, ‘Standard’, ‘Premium’, ‘GeneralPurpose’, ‘BusinessCritical’ 및 ‘Hyperscale’입니다.

MAXSIZE 및 EDITION 인수에는 다음과 같은 규칙이 적용됩니다.

  • EDITION이 지정되었지만 MAXSIZE가 지정되지 않은 경우 해당 버전에 대한 기본값이 사용됩니다. 예를 들어 EDITION이 Standard로 설정되었고 MAXSIZE가 지정되지 않았으면 MAXSIZE가 자동으로 250MB로 설정됩니다.
  • MAXSIZE 또는 EDITION 중 하나도 지정하지 않으면 EDITION은 GeneralPurpose으로 설정되고 MAXSIZE는 32GB로 설정됩니다.

SERVICE_OBJECTIVE

컴퓨팅 크기 및 서비스 목표를 지정합니다.

  • DTU 구매 모델의 경우: S0,, S1,S2, S3S4, S6, S7S9, S12P1P2P4P6, , P11P15
  • 최신 vCore 구매 모델의 경우 계층을 선택하고 vCore 수가 있는 미리 설정된 값 목록에서 vCore n수를 제공합니다. 단일 데이터베이스에 대한 리소스 제한 또는 탄력적 풀에 대한 리소스 제한을 참조하세요.
    • 예시:
    • 범용, 프로비전된 컴퓨팅, 표준 시리즈(Gen5), vCore 8개에 대한 GP_Gen5_8.
    • 범용, 서버리스 컴퓨팅, 표준 시리즈(Gen5), vCore 8개에 대한 GP_S_Gen5_8.
    • 하이퍼스케일, 프로비전된 컴퓨팅, 표준 시리즈(Gen5), vCore 8개에 대한 HS_Gen5_8.
    • 하이퍼스케일, 서버리스 컴퓨팅, 표준 시리즈(Gen5), vCore 8개에 대한 HS_S_Gen5_8.

서비스 목표 설명과 크기, 버전 및 서비스 목표 조합 등의 정보에 대한 자세한 내용은 Azure SQL Database 서비스 계층을 참조하세요. 지정된 SERVICE_OBJECTIVE를 EDITION에서 지원하지 않는 경우 오류가 표시됩니다. SERVICE_OBJECTIVE 값을 한 계층에서 다른 계층으로 변경하려면(예: S1에서 P1로 변경), EDITION 값도 변경해야 합니다. PRS 서비스 목표에 대한 지원이 제거되었습니다.

ELASTIC_POOL (name = <elastic_pool_name>)

적용 대상: 단일 및 풀링된 데이터베이스만. 하이퍼스케일 서비스 계층의 데이터베이스에는 적용되지 않습니다. 탄력적 데이터베이스 풀에서 새 데이터베이스를 만들려면 데이터베이스의 SERVICE_OBJECTIVE를 ELASTIC_POOL로 설정하고 풀의 이름을 제공합니다. 자세한 내용은 SQL Database 탄력적 풀 만들기 및 관리를 참조하세요.

AS COPY OF [source_server_name.]source_database_name

적용 대상: 단일 및 풀링된 데이터베이스만.

데이터베이스를 동일하거나 다른 SQL Database 서버에 복사하는 데 사용합니다 AS COPY OF .

데이터베이스를 다른 데이터베이스 AS COPY OF의 복사본으로 만들 때 옵션을 지정하는 것이 지원되며 괄호로 래핑되어야 합니다. 예들 들어 WITH (BACKUP_STORAGE_REDUNDANCY = 'LOCAL');입니다.

source_server_name 원본 데이터베이스가 위치한 SQL Database 서버의 이름입니다. 이 매개 변수는 원본 데이터베이스와 대상 데이터베이스가 동일한 SQL Database 서버에 있을 때 선택할 수 있습니다.

참고

AS COPY OF 인수는 정규화된 고유 도메인 이름을 지원하지 않습니다. 즉, 서버의 정규화된 도메인 이름은 serverName.database.windows.net이며, 데이터베이스 복사 중 serverName만 사용합니다.

source_database_name

복사할 데이터베이스의 이름입니다.

설명

Azure SQL Database의 데이터베이스에는 데이터베이스가 만들어질 때 설정된 몇 가지 기본 설정이 있습니다. 이러한 기본 설정에 대한 자세한 내용은 DATABASEPROPERTYEX의 값 목록을 참조하세요.

MAXSIZE는 데이터베이스의 크기를 제한하는 기능을 제공합니다. 데이터베이스 크기가 MAXSIZE에 도달하면 40544 오류 코드가 나타납니다. 이 경우, 데이터를 삽입 또는 업데이트하거나 새 개체(예: 테이블, 저장된 프로시저, 뷰 및 함수)를 만들 수 없습니다. 그러나 데이터 읽기 및 삭제, 테이블 자르기, 테이블 및 인덱스 삭제, 인덱스 다시 작성은 가능합니다. 그런 다음, MAXSIZE를 현재 데이터베이스 크기보다 큰 값으로 업데이트하거나 일부 데이터를 삭제하여 스토리지 공간을 비울 수 있습니다. 새 데이터 삽입까지 최대 15분을 지연시킬 수 있습니다.

나중에 크기, 버전 또는 서비스 목표 값을 변경하려면, ALTER DATABASE(Azure SQL Database)를 사용합니다.

데이터베이스 복사본

적용 대상: 단일 및 풀링된 데이터베이스만.

CREATE DATABASE 문을 사용한 데이터베이스 복사는 비동기 작업입니다. 따라서 전체 복사 프로세스가 끝날 때까지 SQL Database 서버에 연결할 필요가 없습니다. CREATE DATABASE 문은 sys.databases에서 항목을 만든 후 데이터베이스 복사 작업이 완료되기 전에 사용자에게 컨트롤을 반환합니다. 즉, 데이터베이스 복사가 진행 중인 동안에 CREATE DATABASE 문을 반환합니다.

  • SQL Database 서버에서 복사 프로세스 모니터링: percentage_completereplication_state_desc 또는 열 또는 state 보기의 열을 쿼리합니다. 데이터베이스 복사를 포함해서 데이터베이스 작업의 상태를 반환하는 것뿐만 아니라 sys.dm_operation_status 보기도 사용할 수 있습니다.

복사 프로세스가 완료되면 트랜잭션에서 대상 데이터베이스가 원본 데이터베이스와 일치하게 됩니다.

AS COPY OF 인수를 사용할 때는 다음 구문 및 의미 체계 규칙에 따라야 합니다.

  • 원본 서버 이름과 복사 대상 서버의 이름은 서로 같아도 되고 달라도 됩니다. 이름이 동일한 경우 이 매개 변수는 선택적으로, 현재 세션의 서버 컨텍스트가 기본값으로 사용됩니다.
  • 원본 및 대상 데이터베이스 이름은 고유하게 지정해야 하며 식별자에 대한 SQL Server 규칙을 따라야 합니다. 자세한 내용은 식별자를 참조하세요.
  • CREATE DATABASE 문은 새 데이터베이스가 만들어질 SQL Database 서버의 master 데이터베이스 컨텍스트 내에서 실행되어야 합니다.
  • 복사를 마친 뒤에는 대상 데이터베이스를 독립적인 데이터베이스로 관리해야 합니다. 원본 데이터베이스와 별도로 새 데이터베이스에 대해 ALTER DATABASEDROP DATABASE 문을 실행할 수 있습니다. 또한 새 데이터베이스를 다른 새 데이터베이스에 복사할 수 있습니다.
  • 데이터베이스 복사가 진행 중인 동안에도 계속해서 원본 데이터베이스에 액세스할 수 있습니다.

자세한 내용은 Transact-SQL을 사용하여 Azure SQL 데이터베이스의 복사본 만들기를 참조하세요.

중요

기본적으로 데이터베이스 복사본은 원본 데이터베이스와 동일한 백업 스토리지 중복성을 사용하여 생성됩니다.

사용 권한

데이터베이스를 만들려면 로그인이 다음 보안 주체 중 하나여야 합니다.

  • 서버 수준 보안 주체 로그인
  • Azure의 논리 서버에 대한 Microsoft Entra 관리자
  • 로그인은 dbmanager 데이터베이스 역할의 멤버입니다.

CREATE DATABASE ... AS COPY OF 구문 사용 관련 추가 요구 사항: 로컬 서버에 문을 실행하는 로그인은 적어도 db_owner 원본 서버에 있어야 합니다. 로그인이 SQL Server 인증을 기반으로 하는 경우, 로컬 서버의 문을 실행하는 로그인에는 동일한 이름과 암호를 사용하여 원본 SQL Database 서버에서 일치하는 로그온이 있어야 합니다.

예제

간단한 예

데이터베이스를 만드는 간단한 예

CREATE DATABASE TestDB1;

에디션을 사용하는 간단한 예

범용 데이터베이스를 만드는 간단한 예제

CREATE DATABASE TestDB2
( EDITION = 'GeneralPurpose' );

추가 옵션이 있는 예

여러 옵션을 사용하는 예

CREATE DATABASE hito
COLLATE Japanese_Bushu_Kakusu_100_CS_AS_KS_WS
( MAXSIZE = 500 MB, EDITION = 'GeneralPurpose', SERVICE_OBJECTIVE = 'GP_Gen5_8' ) ;

데이터베이스 복사본 만들기

데이터베이스의 복사본을 만드는 예

적용 대상: 단일 및 풀링된 데이터베이스만.

CREATE DATABASE escuela
AS COPY OF school;

탄력적 풀에 데이터베이스 생성

S3M100이라는 풀에 새 데이터베이스를 만듭니다.

적용 대상: 단일 및 풀링된 데이터베이스만.

CREATE DATABASE db1 ( SERVICE_OBJECTIVE = ELASTIC_POOL ( name = S3M100 ) ) ;

다른 논리 서버에 데이터베이스 복사본 만들기

다음 예제에서는 단일 데이터베이스에 db_original 대한 범용 서비스 목표에 명명된 db_copy 데이터베이스의 복사본을 만듭니다. 이것은 db_original이 단일 데이터베이스의 탄력적 풀 또는 컴퓨팅 크기(서비스 목표)에 관계없이 적용됩니다.

적용 대상: 단일 및 풀링된 데이터베이스만.

CREATE DATABASE db_copy
  AS COPY OF ozabzw7545.db_original ( EDITION = 'GeneralPurpose', SERVICE_OBJECTIVE = 'GP_Gen5_8' );

다음 예에서는 db_original이라는 이름의 탄력적 풀에 db_copy라는 이름의 ep1 데이터베이스의 복사본을 만듭니다. 이것은 db_original이 단일 데이터베이스의 탄력적 풀 또는 컴퓨팅 크기(서비스 목표)에 관계없이 적용됩니다. db_original이 다른 이름의 탄력적 풀에 있는 경우에도 db_copyep1에 만들어 집니다.

적용 대상: 단일 및 풀링된 데이터베이스만.

CREATE DATABASE db_copy
  AS COPY OF ozabzw7545.db_original
  (SERVICE_OBJECTIVE = ELASTIC_POOL( name = ep1 ) ) ;

지정된 카탈로그 데이터 정렬 값을 사용하여 데이터베이스 만들기

다음 예에서는 카탈로그 데이터 정렬을 데이터베이스 데이터 생성 중에 DATABASE_DEFAULT로 설정하며, 카탈로그 데이터 정렬을 데이터베이스 데이터 정렬과 동일하게 설정합니다.

CREATE DATABASE TestDB3 COLLATE Japanese_XJIS_140 (MAXSIZE = 100 MB, EDITION = 'Basic')
  WITH CATALOG_COLLATION = DATABASE_DEFAULT;

백업을 위해 영역 중복성을 사용하여 데이터베이스 만들기

다음 예제에서는 데이터베이스 백업에 대한 영역 중복성을 설정합니다. 특정 시점 복원 백업과 장기 보존 백업(구성된 경우)은 모두 동일한 백업 스토리지 중복성을 사용합니다.

CREATE DATABASE test_zone_redundancy 
  WITH BACKUP_STORAGE_REDUNDANCY = 'ZONE';

원장 데이터베이스 만들기

CREATE DATABASE MyLedgerDB ( EDITION = 'GeneralPurpose' ) WITH LEDGER = ON;

옵션을 변경하는 동안 데이터베이스의 복사본으로 만들기

다음 예제에서는 다른 서비스 계층 및 백업 스토리지 중복 설정을 포함하여 데이터베이스의 새 복사본에 대한 다양한 옵션을 설정합니다. 기본적으로 데이터베이스 복사본은 원본 데이터베이스와 동일한 설정으로 만들어집니다.

CREATE DATABASE copy_testdb
AS COPY OF [test_db]
  (EDITION = 'GeneralPurpose', SERVICE_OBJECTIVE = 'GP_Gen5_8')
  WITH (BACKUP_STORAGE_REDUNDANCY = 'LOCAL');

* SQL Managed Instance *

 

Azure SQL Managed Instance

개요

Azure SQL Managed Instance에서 이 문은 데이터베이스를 만드는 데 사용됩니다. 관리되는 인스턴스에서 데이터베이스를 만들 때 데이터베이스 이름 및 데이터 정렬을 지정합니다.

구문

구문 표기 규칙에 대한 자세한 내용은 Transact-SQL 구문 표기 규칙을 참조하세요.

CREATE DATABASE database_name [ COLLATE collation_name ]
[ WITH <with_options> [,..n]]
[;]

<with_options> ::=
{
  LEDGER = { ON | OFF }
}

중요

관리되는 인스턴스에서 데이터베이스에 대한 파일을 추가하거나 포함을 설정하려면 ALTER DATABASE 문을 사용합니다.

SQL 관리형 인스턴스의 경우 초기 MAXSIZE는 암시적으로 현재 디스크 크기로 설정되며 Azure Portal에서 디스크 크기를 확장할 때 자동으로 변경되지 않습니다. 디스크를 확장한 후 데이터베이스 파일 전체 오류를 방지하려면 ALTER DATABASE MAXSIZE를 확장해야 합니다.

인수

database_name

새 데이터베이스의 이름입니다. 이 이름은 SQL Server에서 고유해야 하며 식별자에 대한 SQL Server 규칙을 따라야 합니다. 자세한 내용은 식별자를 참조하세요.

Collation_name

데이터베이스의 기본 데이터 정렬을 지정합니다. 데이터 정렬 이름으로는 Windows 데이터 정렬 이름 또는 SQL 데이터 정렬 이름을 사용할 수 있습니다. 지정되지 않는 경우 해당 데이터베이스가 기본 데이터 정렬 SQL_Latin1_General_CP1_CI_AS에 할당됩니다.

Windows 및 SQL 데이터 정렬 이름에 대한 자세한 내용은 COLLATE(Transact-SQL)를 참조하세요.

LEDGER = {ON | OFF}

ON으로 설정된 경우 모든 사용자 데이터의 무결성이 보호되는 원장 데이터베이스를 만듭니다. 원장 데이터베이스에는 원장 테이블만 만들 수 있습니다. 기본값은 OFF입니다. 데이터베이스를 만든 후에는 LEDGER 옵션 값을 변경할 수 없습니다. 자세한 내용은 원장 데이터베이스 구성을 참조하세요.

설명

Azure SQL Database의 데이터베이스에는 데이터베이스가 만들어질 때 설정된 몇 가지 기본 설정이 있습니다. 이러한 기본 설정에 대한 자세한 내용은 DATABASEPROPERTYEX의 값 목록을 참조하세요.

중요

CREATE DATABASE 문은 Transact-SQL 일괄 처리의 유일한 문이어야 합니다.

다음은 CREATE DATABASE 제한 사항입니다.

  • 파일 및 파일 그룹을 정의할 수 없습니다.

  • WITH을 제외하고 WITH LEDGER옵션은 지원되지 않습니다.

    해결 방법으로 ALTER DATABASECREATE DATABASE 뒤에 사용하여 데이터베이스 옵션을 설정하고 파일을 추가합니다.

사용 권한

데이터베이스를 만들려면 로그인은 다음 중 하나여야 합니다.

  • 서버 수준 보안 주체 로그인
  • Azure의 논리 서버에 대한 Microsoft Entra 관리자
  • 로그인은 dbcreator 데이터베이스 역할의 멤버입니다.

예제

간단한 예

데이터베이스를 만드는 간단한 예

CREATE DATABASE TestDB1;

원장 데이터베이스 만들기

CREATE DATABASE MyLedgerDB WITH LEDGER = ON;

* Azure Synapse
Analytics *

 

Azure Synapse Analytics

개요

Azure Synapse에서 이 문을 Azure SQL Database 서버와 함께 사용하여 전용 SQL 풀을 만들 수 있습니다. 이 문을 사용하여 데이터베이스 이름, 데이터 정렬, 최대 크기, 버전 및 서비스 목표를 지정합니다.

  • CREATE DATABASE는 Gen2 서비스 수준을 사용하여 독립 실행형 전용 SQL 풀(이전의 SQL DW)을 지원합니다.
  • CREATE DATABASE는 Azure Synapse Analytics 작업 영역의 전용 SQL 풀에 대해 지원되지 않습니다. 대신 Azure Portal을 사용합니다.
  • CREATE DATABASE는 Azure Synapse Analytics의 서버리스 SQL 풀에서 지원됩니다.

구문

구문 표기 규칙에 대한 자세한 내용은 Transact-SQL 구문 표기 규칙을 참조하세요.

CREATE DATABASE database_name [ COLLATE collation_name ]
(
    [ MAXSIZE = {
          250 | 500 | 750 | 1024 | 5120 | 10240 | 20480 | 30720
        | 40960 | 51200 | 61440 | 71680 | 81920 | 92160 | 102400
        | 153600 | 204800 | 245760
      } GB ,
    ]
    EDITION = 'datawarehouse',
    SERVICE_OBJECTIVE = {
          'DW100c' | 'DW200c' | 'DW300c' | 'DW400c' | 'DW500c'
        | 'DW1000c' | 'DW1500c' | 'DW2000c' | 'DW2500c' | 'DW3000c' | 'DW5000c'
        | 'DW6000c' | 'DW7500c' | 'DW10000c' | 'DW15000c' | 'DW30000c'
    }
)
[;]

인수

database_name

새 데이터베이스의 이름입니다. 이 이름은 AZURE SQL Database 및 Azure Synapse Analytics 데이터베이스에서 두 데이터베이스를 모두 호스트하고 식별자에 대한 SQL Server 규칙을 준수할 수 있는 SQL Server에서 고유해야 합니다. 자세한 내용은 식별자를 참조하세요.

collation_name

데이터베이스의 기본 데이터 정렬을 지정합니다. 데이터 정렬 이름으로는 Windows 데이터 정렬 이름 또는 SQL 데이터 정렬 이름을 사용할 수 있습니다. 지정되지 않는 경우 해당 데이터베이스가 기본 데이터 정렬 SQL_Latin1_General_CP1_CI_AS에 할당됩니다.

Windows 및 SQL 데이터 정렬 이름에 대한 자세한 내용은 COLLATE(Transact-SQL)를 참조하세요.

MAXSIZE

기본값은 245,760GB(240TB)입니다.

적용 대상: Compute Gen1에 최적화됨

데이터베이스의 최대 허용 크기입니다. 데이터베이스는 MAXSIZE 이상으로 커질 수 없습니다.

적용 대상: Compute Gen2에 최적화됨

데이터베이스의 rowstore 데이터에 허용되는 최대 크기입니다. Rowstore 테이블, columnstore 인덱스의 deltastore 또는 클러스터된 columnstore 인덱스의 비클러스터된 인덱스에 저장된 데이터는 MAXSIZE 보다 커질 수 없습니다. columnstore 형식으로 압축된 데이터에는 크기 제한이 없으며 MAXSIZE에 의해 제한되지 않습니다.

EDITION

데이터베이스의 서비스 계층을 지정합니다. Azure Synapse Analytics의 경우 datawarehouse를 사용합니다.

SERVICE_OBJECTIVE

컴퓨팅 크기(서비스 목표)를 지정합니다. Gen2에 대한 서비스 수준은 cDWU(컴퓨팅 데이터 웨어하우스 단위)로 측정됩니다(예: DW2000c). Gen1 서비스 수준은 DWU로 측정됩니다(예: DW2000). Azure Synapse의 서비스 목표에 대한 자세한 내용은 DWU(데이터 웨어하우스 단위)를 참조하세요. Gen1 서비스 목표(더 이상 나열되지 않음)는 더 이상 지원되지 않으며 다음과 같은 오류가 발생할 수 있습니다. Azure SQL Data Warehouse Gen1 has been deprecated in this region. Please use SQL Analytics in Azure Synapse.

설명

DATABASEPROPERTYEX를 사용하여 데이터베이스 속성을 확인합니다.

나중에 최대 크기 또는 서비스 목표 값을 변경하려면 ALTER DATABASE - Azure Synapse Analytics를 사용합니다.

Azure Synapse는 COMPATIBILITY_LEVEL 130으로 설정되어 있으며 변경할 수 없습니다. 자세한 내용은 Azure SQL Database의 호환성 수준 130을 통해 개선된 쿼리 성능을 참조하세요.

사용 권한

필요한 권한

  • 프로비전 프로세스에 의해 생성된 서버 수준 보안 주체 로그인 또는
  • dbmanager 데이터 베이스 역할의 멤버

오류 처리

데이터베이스 크기가 MAXSIZE에 도달하면 40544 오류 코드가 나타납니다. 이 경우, 데이터를 삽입 및 업데이트하거나 새 개체(예: 테이블, 저장된 프로시저, 뷰 및 함수)를 만들 수 없습니다. 데이터 읽기 및 삭제, 테이블 자르기, 테이블 및 인덱스 삭제 및 인덱스 다시 작성은 여전히 가능합니다. 그런 다음 MAXSIZE를 현재 데이터베이스 크기보다 큰 값으로 업데이트하거나 일부 데이터를 삭제하여 스토리지 공간을 비울 수 있습니다. 새 데이터 삽입까지 최대 15분을 지연시킬 수 있습니다.

제한 사항

새 데이터베이스를 만들려면 master 데이터베이스에 연결해야 합니다.

CREATE DATABASE 문은 Transact-SQL 일괄 처리의 유일한 문이어야 합니다.

데이터베이스를 만든 후에는 데이터베이스 데이터 정렬을 변경할 수 없습니다.

예제: Azure Synapse Analytics

A. 간단한 예

독립 실행형 전용 SQL 풀(이전의 SQL DW)을 만드는 간단한 예제입니다. 이렇게 하면 가장 작은 최대 크기(10,240GB), 기본 데이터 정렬(SQL_Latin1_General_CP1_CI_AS), 가장 작은 Gen2 서비스 목표(DW100)가 있는 데이터베이스가 만들어집니다.

CREATE DATABASE TestDW
(EDITION = 'datawarehouse', SERVICE_OBJECTIVE='DW100c');

B. 모든 옵션을 사용하여 데이터 웨어하우스 데이터베이스 만들기

10테라바이트 독립 실행형 전용 SQL 풀(이전의 SQL DW)을 만드는 간단한 예제입니다.

CREATE DATABASE TestDW COLLATE Latin1_General_100_CI_AS_KS_WS
(MAXSIZE = 10240 GB, EDITION = 'datawarehouse', SERVICE_OBJECTIVE = 'DW1000c');

C. Synapse Analytics 서버리스 SQL 풀의 간단한 예제

이 예제에서는 데이터 정렬(Latin1_General_100_CI_AS_KS_WS)을 지정하여 서버리스 풀에 데이터베이스를 만듭니다.

CREATE DATABASE TestDW COLLATE Latin1_General_100_CI_AS_KS_WS

* Analytics Platform
System (PDW) *

 

분석 플랫폼 시스템

개요

Analytics Platform System에서 이 문은 Analytics Platform System 어플라이언스에서 새 데이터베이스를 만드는 데 사용됩니다. 이 문을 사용하여 어플라이언스 데이터베이스와 관련된 모든 파일을 만들고 데이터베이스 테이블 및 트랜잭션 로그에 대한 최대 크기 및 자동 증가 옵션을 설정합니다.

구문

구문 표기 규칙에 대한 자세한 내용은 Transact-SQL 구문 표기 규칙을 참조하세요.

CREATE DATABASE database_name
WITH (
    [ AUTOGROW = ON | OFF , ]
    REPLICATED_SIZE = replicated_size [ GB ] ,
    DISTRIBUTED_SIZE = distributed_size [ GB ] ,
    LOG_SIZE = log_size [ GB ] )
[;]

인수

database_name

새 데이터베이스의 이름입니다. 허용되는 데이터베이스 이름에 대한 자세한 내용은 Analytics Platform System(PDW) 제품 설명서에서 "개체 명명 규칙" 및 "예약된 데이터베이스 이름"을 참조하세요.

AUTOGROW = ON | OFF

이 데이터베이스에 대한 replicated_size, distributed_sizelog_size 매개 변수가 지정된 크기를 넘어 필요에 따라 자동으로 증가하는지 여부를 지정합니다. 기본값은 OFF입니다.

AUTOGROW가 ON인 경우 replicated_size, distributed_sizelog_size가 각 데이터 삽입, 업데이트 또는 이미 할당된 것보다 더 많은 스토리지 용량이 필요한 기타 작업의 필요에 따라(지정된 초기 크기의 블록에서가 아니라) 성장하게 됩니다.

AUTOGROW가 OFF이면 크기가 자동으로 증가하지 않습니다. Analytics Platform System(PDW)은 replicated_size, distributed_size 또는 log_size가 지정된 값을 초과하여 성장할 것을 요구하는 작업을 시도할 경우 오류를 반환합니다.

AUTOGROW는 모든 크기에 대해 ON이거나 OFF입니다. 예를 들어 log_size에 대해 AUTOGROW를 ON으로 설정하는 것이 가능하지 않지만 replicated_size에 대해서는 ON으로 설정하지 않습니다.

replicated_size [ GB ]

양수입니다. 각 컴퓨팅 노드에서 복제된 테이블과 해당 데이터에 할당된 총 공간에 대한 크기(정수 또는 10진 기가바이트로)를 설정합니다. 최소 및 최대 replicated_size 요구 사항은 Analytics Platform System(PDW) 제품 설명서에서 "최소 및 최대 값"을 참조하세요.

AUTOGROW가 ON인 경우 복제된 테이블이 이 제한을 초과해 성장하도록 허용됩니다.

AUTOGROW가 OFF인 경우 사용자가 replicated_size를 초과하여 크기가 증가하는 식으로 새로 복제된 테이블을 만들고 기존 복제된 테이블에 데이터를 삽입하고 또는 기존 복제된 테이블을 업데이트하려고 하면 오류가 반환됩니다.

distributed_size [ GB ]

양수입니다. 어플라이언스 전반에 걸쳐 복제된 테이블(및 해당 데이터)에 할당된 총 공간에 대한 정수 또는 10진 기가바이트로 표시된 크기입니다. 최소 및 최대 distributed_size 요구 사항은 Analytics Platform System(PDW) 제품 설명서에서 "최소 및 최대 값"을 참조하세요.

AUTOGROW가 ON인 경우 분산된 테이블이 이 제한을 초과해 성장하도록 허용됩니다.

AUTOGROW가 OFF인 경우 사용자가 distributed_size를 초과하여 크기가 증가하는 식으로 새로 분산된 테이블을 만들고 기존 분산된 테이블에 데이터를 삽입하고 또는 기존 분산된 테이블을 업데이트하려고 하면 오류가 반환됩니다.

log_size [ GB ]

양수입니다. 어플라이언스 전반에 걸친 트랜잭션 로그에 대한 크기(정수 또는 10진 기가바이트로 표시된)입니다.

최소 및 최대 log_size 요구 사항은 Analytics Platform System(PDW) 제품 설명서에서 "최소 및 최대 값"을 참조하세요.

AUTOGROW가 ON인 경우 로그 파일은 이 제한을 초과하여 성장하도록 허용됩니다. 로그 파일의 크기를 원래 크기로 줄이려면 DBCC SHRINKLOG(Azure Synapse Analytics) 문을 사용합니다.

AUTOGROW가 OFF인 경우 log_size를 초과한 개별 컴퓨팅 노드에서 로그 크기를 증가시키는 모든 작업에 대해서 사용자에게 오류가 반환됩니다.

사용 권한

CREATE ANY DATABASE 데이터베이스에서 master 권한 또는 sysadmin 고정 서버 역할에서 멤버 자격이 필요합니다.

다음 예에서는 데이터베이스 사용자 Fay에게 데이터베이스를 만들 수 있는 권한을 제공합니다.

USE master;
GO
GRANT CREATE ANY DATABASE TO [Fay];
GO

설명

SQL Server 2014(12.x)에 대한 호환성 수준인 데이터베이스 호환성 수준 120으로 데이터베이스를 만듭니다. 이렇게 하면 데이터베이스는 PDW가 사용하는 모든 SQL Server 2014(12.x) 기능을 사용할 수 있습니다.

제한 사항

명시적 트랜잭션에서는 CREATE DATABASE 문을 사용할 수 없습니다. 자세한 내용은 을 참조하십시오.

데이터베이스의 최소 및 최대 제약 조건에 대한 자세한 내용은 Analytics Platform System(PDW) 제품 설명서에서 "최소 및 최대 값"을 참조하세요.

데이터베이스를 만들 경우 다음 크기의 총합계를 할당하기 위해 각 컴퓨팅 노드에 충분히 사용할 수 있는 여유 공간이 있어야 합니다.

  • replicated_table_size 크기의 테이블이 있는 SQL Server 데이터베이스입니다.
  • (distributed_table_size / 컴퓨팅 노드 수) 크기의 테이블이 있는 SQL Server 데이터베이스입니다.
  • (log_size / 컴퓨팅 노드 수) 크기의 SQL Server 로그입니다.

잠금

DATABASE 개체에 대한 공유 잠금을 사용합니다.

메타데이터

이 작업이 성공하면 이 데이터베이스에 대한 항목이 sys.databases 및 sys.objects 메타데이터 뷰에 표시됩니다.

예제: 분석 플랫폼 시스템(PDW)

A. 기본 데이터베이스 만들기 예제

다음 예제에서는 복제된 테이블에 대해 컴퓨팅 노드당 100GB, 분산된 테이블에 대해 어플라이언스당 500GB, 트랜잭션 로그에 대해 어플라이언스당 100GB의 스토리지 용량이 있는 mytest 데이터베이스를 만듭니다. 이 예제에서는 AUTOGROW가 기본으로 Off로 설정돼 있습니다.

CREATE DATABASE mytest
  WITH
    (REPLICATED_SIZE = 100 GB,
    DISTRIBUTED_SIZE = 500 GB,
    LOG_SIZE = 100 GB );

다음 예제에서는 AUTOGROW가 켜진 경우를 제외하고 위와 동일한 매개 변수가 있는 mytest 데이터베이스를 만듭니다. 이렇게 하면 데이터베이스가 지정된 크기 매개 변수를 벗어나 성장할 수 있습니다.

CREATE DATABASE mytest
  WITH
    (AUTOGROW = ON,
    REPLICATED_SIZE = 100 GB,
    DISTRIBUTED_SIZE = 500 GB,
    LOG_SIZE = 100 GB);

B. 부분 기가바이트 크기를 사용하여 데이터베이스 만들기

다음 예제에서는 복제된 테이블에 대해 컴퓨팅 노드당 1.5GB, 분산된 테이블에 대해 어플라이언스당 5.25GB, 트랜잭션 로그에 대해 어플라이언스당 10GB의 스토리지 용량을 가진 그리고 AUTOGROW가 Off로 설정된 mytest 데이터베이스를 만듭니다.

CREATE DATABASE mytest
  WITH
    (REPLICATED_SIZE = 1.5 GB,
    DISTRIBUTED_SIZE = 5.25 GB,
    LOG_SIZE = 10 GB);