ORACLE 数据库设计 多对多关系

WBOY
풀어 주다: 2016-06-07 15:21:09
원래의
1224명이 탐색했습니다.

关于数据库两张表多对多的关系设计,之前以为多对多关系,只要两张表存在各自对方表的主键就行。殊不知这种理解是错误的,今天借此时间总结一下。 数据库多对多表设计,假设使用主外键关系设计多对多表关系,会造成: 1、对一张表进行DML语句时,该表对应的

关于数据库两张表多对多的关系设计,之前以为多对多关系,只要两张表存在各自对方表的主键就行。殊不知这种理解是错误的,今天借此时间总结一下。

数据库多对多表设计,假设使用主外键关系设计多对多表关系,会造成:

1、对一张表进行DML语句时,该表对应的外键会影响另外一张表的数据,产生级联删除问题;

2、因为是多对多的关系,会产生大量冗余数据;

--假设以上2种都允许存在,系统将就凑合也还可用。致命一点是:

3、多对多关系,会导致主键重复(主键是不可重复的!!!)。

故对于多对多关系表设计,必须使用中间表进行管理,各自表的主键构成中间表的联合主键。

 

 

 

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!