다음을 통해 공유


참조 무결성 제약 조건

EDM(엔터티 데이터 모델)의 참조 무결성 제약 조건은 관계형 데이터베이스의 참조 무결성 제약 조건과 비슷합니다. 데이터베이스 테이블의 열에서 다른 테이블의 기본 키를 참조하는 방식과 동일하게 엔터티 형식속성은 다른 엔터티 형식의 엔터티 키를 참조할 수 있습니다. 참조되는 엔터티 형식을 제약 조건의 ‘주 끝’이라고 합니다. 주 끝을 참조하는 엔터티 형식은 제약 조건의 ‘종속 끝’이라고 합니다.

참조 무결성 제약 조건은 두 엔터티 형식 간 연결의 일부로 정의됩니다. 참조 무결성 제약 조건 정의에서는 다음 정보를 지정합니다.

  • 제약 조건의 주 끝 (엔터티 키가 종속 끝에서 참조되는 엔터티 형식)

  • 주 끝의 엔터티 키

  • 제약 조건의 종속 끝 (주 끝의 엔터티 키를 참조하는 속성이 있는 엔터티 형식)

  • 종속 끝의 참조 속성

EDM의 참조 무결성 제약 조건은 항상 올바른 연결이 존재하도록 보장하는 데 사용됩니다. 자세한 내용은 외래 키 속성을 참조하세요.

예시

다음 다이어그램에서는 두 연결 WrittenByPublishedBy의 개념적 모델을 보여 줍니다. Book 엔터티 형식에는 PublisherId 연결에 참조 무결성 제약 조건을 정의할 때 Publisher 엔터티 형식의 엔터티 키를 참조하는 PublishedBy 속성이 있습니다.

RefConstraintModel

ADO.NET Entity FrameworkCSDL(개념 스키마 정의 언어)이라는 DSL(Domain-Specific Language)을 사용하여 개념적 모델을 정의합니다. 다음 CSDL에서는 위의 개념적 모델에 표시된 PublishedBy 연결에 참조 무결성 제약 조건을 정의합니다.

<Association Name="PublishedBy">
  <End Type="BooksModel.Book" Role="Book" Multiplicity="*" >
  </End>
  <End Type="BooksModel.Publisher" Role="Publisher" Multiplicity="1" />
  <ReferentialConstraint>
    <Principal Role="Publisher">
      <PropertyRef Name="Id" />
    </Principal>
    <Dependent Role="Book">
      <PropertyRef Name="PublisherId" />
    </Dependent>
  </ReferentialConstraint>
</Association>

참고 항목