UNIQUE 제약 조건 만들기

SQL Server 2012에서 SQL Server Management Studio 또는 Transact-SQL을 사용하여 UNIQUE 제약 조건을 만들어서 기본 키에 참여하지 않는 특정 열에 입력하는 값이 중복되지 않도록 할 수 있습니다. UNIQUE 제약 조건을 만들면 해당하는 고유 인덱스가 자동으로 만들어집니다.

항목 내용

  • 시작하기 전 주의 사항

    보안

  • UNIQUE 제약 조건을 만들려면

    SQL Server Management Studio

    Transact-SQL

시작하기 전 주의 사항

보안

사용 권한

테이블에 대한 ALTER 권한이 필요합니다.

맨 위로 이동 링크와 함께 사용되는 화살표 아이콘[Top]

SQL Server Management Studio 사용

UNIQUE 제약 조건을 만들려면

  1. 개체 탐색기에서 UNIQUE 제약 조건을 추가하려는 테이블을 마우스 오른쪽 단추로 클릭하고 디자인을 선택합니다.

  2. 테이블 디자이너 메뉴에서 인덱스/키를 클릭합니다.

  3. 인덱스/키 대화 상자에서 추가를 클릭합니다.

  4. 일반 아래의 표에서 형식을 선택하고 속성 오른쪽에 있는 드롭다운 목록 상자에서 고유 키를 선택합니다.

  5. 파일 메뉴에서 table name 저장을 클릭합니다.

맨 위로 이동 링크와 함께 사용되는 화살표 아이콘[Top]

Transact-SQL 사용

UNIQUE 제약 조건을 만들려면

  1. 개체 탐색기에서 데이터베이스 엔진 인스턴스에 연결합니다.

  2. 표준 도구 모음에서 새 쿼리를 클릭합니다.

  3. 다음 예를 복사하여 쿼리 창에 붙여 넣고 실행을 클릭합니다. 이 예에서는 TransactionHistoryArchive4 테이블을 만들고 TransactionID 열에 UNIQUE 제약 조건을 만듭니다.

    USE AdventureWorks2012;
    GO
    CREATE TABLE Production.TransactionHistoryArchive4
     (
       TransactionID int NOT NULL, 
       CONSTRAINT AK_TransactionID UNIQUE(TransactionID) 
    ); 
    GO
    

기존 테이블에 UNIQUE 제약 조건을 만들려면

  1. 개체 탐색기에서 데이터베이스 엔진 인스턴스에 연결합니다.

  2. 표준 도구 모음에서 새 쿼리를 클릭합니다.

  3. 다음 예를 복사하여 쿼리 창에 붙여 넣고 실행을 클릭합니다. 이 예에서는 Person.Password 테이블에서 PasswordHash 및 PasswordSalt 열에 UNIQUE 제약 조건을 만듭니다.

    USE AdventureWorks2012; 
    GO
    ALTER TABLE Person.Password 
    ADD CONSTRAINT AK_Password UNIQUE (PasswordHash, PasswordSalt); 
    GO
    

새 테이블에 UNIQUE 제약 조건을 만들려면

  1. 개체 탐색기에서 데이터베이스 엔진 인스턴스에 연결합니다.

  2. 표준 도구 모음에서 새 쿼리를 클릭합니다.

  3. 다음 예를 복사하여 쿼리 창에 붙여 넣고 실행을 클릭합니다. 이 예에서는 테이블을 만들고 TransactionID 열에 UNIQUE 제약 조건을 정의합니다.

    USE AdventureWorks2012;
    GO
    CREATE TABLE Production.TransactionHistoryArchive2
    (
       TransactionID int NOT NULL,
       CONSTRAINT AK_TransactionID UNIQUE(TransactionID)
    );
    GO
    

    자세한 내용은 ALTER TABLE(Transact-SQL), CREATE TABLE(Transact-SQL)table_constraint(Transact-SQL)를 참조하십시오.

맨 위로 이동 링크와 함께 사용되는 화살표 아이콘[Top]