>  기사  >  데이터 베이스  >  테이블에 외래 키를 설정하면 어떤 유형의 데이터 무결성이 달성됩니까?

테이블에 외래 키를 설정하면 어떤 유형의 데이터 무결성이 달성됩니까?

(*-*)浩
(*-*)浩원래의
2019-07-26 15:05:1712051검색

테이블에 외래 키를 설정하면 참조 무결성이 달성됩니다.

테이블에 외래 키를 설정하면 어떤 유형의 데이터 무결성이 달성됩니까?

참조 무결성을 위해서는 관계에서 존재하지 않는 엔터티에 대한 참조가 허용되지 않아야 합니다. 엔티티 무결성은 데이터 일관성을 보장하기 위해 관계형 모델이 충족해야 하는 무결성 제약 조건입니다. 참조 무결성은 참조 무결성이라고도 합니다. (권장 학습: MySQL 비디오 튜토리얼)

참조 무결성은 관계형 모델의 완전한 제약 중 하나이며 데이터 무결성의 한 유형입니다. 다른 항목에는 엔터티 무결성 및 사용자 정의 무결성이 포함됩니다.

참조 무결성 규칙: 속성 또는 속성 그룹 F가 기본 관계 R의 외래 키이고 기본 관계 S의 기본 키 Ks에 해당하는 경우(기본 관계 R과 S가 반드시 다른 관계일 필요는 없음) ), R의 경우 F의 각 튜플 값은

(1) null 값이어야 하며 F의 각 속성 값은 null 값입니다.

(2) S의 튜플에 있는 기본 키 값(기본 코드 값)입니다.

즉, 참조 관계의 속성 값은 참조 관계에서 찾거나 null 값을 가져와야 합니다. 그렇지 않으면 데이터베이스의 의미를 따르지 않습니다. 테이블의 데이터 업데이트, 삭제, 삽입 등의 실제 작업에서는 서로 관련된 다른 테이블의 데이터를 참조하여 해당 테이블의 데이터 작업이 올바른지 확인합니다. 거부됨

Property

참조 무결성은 테이블 간 규칙입니다. 영구적인 관계가 있는 관련 테이블의 경우 레코드를 업데이트, 삽입 또는 삭제할 때 하나만 변경되고 다른 하나는 변경되지 않으면 데이터 무결성이 영향을 받습니다.

예를 들어 상위 테이블의 키 값을 수정한 후 , 하위 테이블은 상위 테이블의 레코드를 삭제한 후 그에 따라 키워드 값이 변경되지 않으며 하위 테이블의 해당 레코드가 삭제되지 않아 이러한 레코드가 하위 테이블에 삽입된 레코드에 대해 고아 레코드가 됩니다. 상위 테이블 등에 해당 키워드 값이 있는 레코드가 없습니다. 이러한 설계 테이블 간의 데이터 무결성을 총칭하여 참조 무결성이라고 합니다.

참조 무결성은 두 개의 관련 테이블 간의 제약 조건입니다. 특히 슬레이브 테이블의 각 레코드에 대한 외래 키 값은 마스터 테이블에 존재해야 합니다. 따라서 두 테이블 사이에 관계가 설정된 경우. , 한 관계에서 수행된 작업은 다른 테이블의 레코드에 영향을 미칩니다.

참조 무결성이 구현되면 기본 테이블에 관련 레코드가 없으면 관련 테이블에 레코드를 추가할 수 없습니다. 관련 테이블에 일치하는 레코드가 있는 경우 메인 테이블의 레코드를 삭제할 수 없으며, 관련 테이블에 관련 레코드가 있는 경우 메인 테이블의 기본 키 값을 변경할 수 없습니다.

즉, 참조 무결성이 구현된 후 테이블의 기본 키 필드에 대해 작업을 수행할 때 시스템은 자동으로 기본 키 필드를 확인하여 해당 필드가 추가, 수정 또는 삭제되었는지 확인합니다. 기본 키 수정이 참조 무결성 요구 사항을 위반하는 경우 시스템은 자동으로 참조 무결성을 적용합니다.

더 많은 MySQL 관련 기술 기사를 보려면

MySQL Tutorial 칼럼을 방문하여 알아보세요!

위 내용은 테이블에 외래 키를 설정하면 어떤 유형의 데이터 무결성이 달성됩니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.