ORACLE数据库设计 多对多关系
来源:互联网 发布:虚拟股票操作软件 编辑:程序博客网 时间:2024/06/08 19:32
关于数据库两张表多对多的关系设计,之前以为多对多关系,只要两张表存在各自对方表的主键就行。而这种理解是错误的,总结如下。
数据库多对多表设计,假设使用主外键关系设计多对多表关系,会造成:
1、对一张表进行DML语句时,该表对应的外键会影响另外一张表的数据,产生级联删除问题;
2、因为是多对多的关系,会产生大量冗余数据;
--假设以上2种都允许存在,系统凑合也还可用。致命一点是:
3、多对多关系,会导致主键重复。
故对于多对多关系表设计,必须使用中间表进行管理,各自表的主键构成中间表的联合主键。
--创建联合主键
先删除表中原有主键
alter table tablename drop column columnname;
创建联合主键
alter table tablename add constraint unionpkname primary key(colum1, colum2);
--直接在创表时候创建联合主键
create table t_engineer(
e_id nubmer(10),
t_id number(10),
primary key(e_id,t_id),
foreign key (e_id) references t_tenger(id),
foreign key (d_id) references t_denger(id)
)
0 0
- ORACLE 数据库设计 多对多关系
- ORACLE数据库设计 多对多关系
- 数据库设计一对多、多对多关系
- 数据库设计多对多关系的几种形态
- 数据库设计多对多关系的几种形态
- 数据库设计多对多关系的几种形态
- 数据库设计多对多关系的几种形态
- 数据库设计多对多关系的几种形态
- 数据库设计多对多关系的几种形态
- 数据库设计多对多关系的几种形态
- 数据库设计多对多关系的几种形态
- 数据库中多对多的关系设计
- 数据库设计多对多关系的几种形态
- 数据库中多对多的关系设计
- 数据库中多对多的关系设计
- 数据库设计中的多对多关系与一对多关系
- 多对多关系如何设计表
- 数据库设计多对多关系的几种形态(7种)。
- bzoj2001: [Hnoi2010]City 城市建设
- 安卓APP使用H5弹出ALERT 支持JS
- Google play ASO 关键字指南
- maven版本控制方案
- 使用ab进行压力测试详解
- ORACLE数据库设计 多对多关系
- http缓存提高性能
- git撤回已经push到远端的版本
- npm scripts详解
- ChemDraw如何画立体图?
- idea配置文件
- swoole 安装
- selenium常用控件的操作
- 【leetcode】对撞指针应用之回文字符串判断(忽略大小写,以及出数字外其他字符)