业务需求:用户表r_user保存用户名等信息。现需要给每个用户设置工作基地,一个用户可以有多个工作基地,多个用户也可以有一个工作基地,即多对多关系。(外键,若有两个表A,B,C是A的主键,而B中也有C字段,则C就是表B的外键,外键约束主要用来维护两个表之间数据的一致性)

设计方案:

方案一:建立一张用户基地表,与r_user与用户基地表,保持一对多的关系,如图所示,r_user的主键id做为r_user_base的外键user_id。通过r_user中的id,在r_user_base表中load该用户的所有工作基地。

方案二:建立一张个基地表base_info保存目前存在的所有基地,再建一张user_base关系表。如图所示,关系表user_base有两个外键user_id与base_id

方案一的特点是,只需要键一张表就可以完成业务需求。缺点是不够模块化,如果在其它地方还要用到基地信息,则还要再建基地表

方案二的特点是,用一张关系表连接两张信息表。便于信息表的维护与重复利用。

基于业务需求与以后扩展及重用性考虑,采用方案二实现需求。

在MySQL 3.23.44版本后,InnoDB引擎类型的表支持了外键约束。

外键的使用条件:

1.两个表必须是InnoDB表,MyISAM表暂时不支持外键(据说以后的版本有可能支持,但至少目前不支持);

2.外键列必须建立了索引,MySQL 4.1.2以后的版本在建立外键时会自动创建索引,但如果在较早的版本则需要显示建立;

3.外键关系的两个表的列必须是数据类型相似,也就是可以相互转换类型的列,比如int和tinyint可以,而int和char则不可以;

外键的定义语法:

[CONSTRAINT symbol] FOREIGN KEY [id] (index_col_name, ...)

REFERENCES tbl_name (index_col_name, ...)

[ON DELETE {RESTRICT | CASCADE | SET NULL | NO ACTION | SET DEFAULT}]

[ON UPDATE {RESTRICT | CASCADE | SET NULL | NO ACTION | SET DEFAULT}]

 cascade方式 

在父表上update/delete记录时,同步update/delete掉子表的匹配记录 
   On delete cascade从mysql3.23.50开始可用; on update cascade从mysql4.0.8开始可用 。

set null方式 

在父表上update/delete记录时,将子表上匹配记录的列设为null

要注意子表的外键列不能为not null

On delete set null从mysql3.23.50开始可用; on update set null从mysql4.0.8开始可用 
No action方式

如果子表中有匹配的记录,则不允许对父表对应候选键进行update/delete操作 
   这个是ANSI SQL-92标准,从mysql4.0.8开始支持 
Restrict方式 

同no action, 都是立即检查外键约束

建立人员信息表:

 CREATE TABLE `r_user` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`NAME` varchar(20) DEFAULT NULL,
`PASSWORD` varchar(50) DEFAULT NULL,
`STAFF_NUM` varchar(20) DEFAULT NULL,
`USER_NAME` varchar(20) DEFAULT NULL,
PRIMARY KEY (`id`),
) ENGINE=InnoDB AUTO_INCREMENT=54 DEFAULT CHARSET=utf8 

建立基地信息表

 CREATE TABLE `branch_info` (
`ID` bigint(20) NOT NULL AUTO_INCREMENT,
`BRANCH_CODE` varchar(255) DEFAULT NULL,
`BRANCH_DESC` varchar(255) DEFAULT NULL,
PRIMARY KEY (`ID`)
) ENGINE=InnoDB AUTO_INCREMENT=19 DEFAULT CHARSET=utf8 

关系表:

 CREATE TABLE `user_work_base` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`version` int(11) NOT NULL,
`user_id` bigint(20) NOT NULL ,
`base_id` bigint(20) NOT NULL ,
PRIMARY KEY (`id`),
CONSTRAINT `user_work_base_ibfk_1` FOREIGN KEY (`user_id`) REFERENCES `r_user` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
CONSTRAINT `user_work_base_ibfk_2` FOREIGN KEY (`base_id`) REFERENCES `branch_info` (`ID`) ON DELETE CASCADE ON UPDATE CASCADE
) ENGINE=InnoDB AUTO_INCREMENT=37 DEFAULT CHARSET=utf8

删除人员r_user表中人员A,关系表user_base自动删除A的关系数据。

如果外键使用Restrict方式,只删除A,则报错。

Cannot delete or update a parent row: a foreign key constraint fails (`maircrew`,`user_work_base`, CONSTRAINT `FK41EB46D32AA89EA0`

FOREIGN KEY (`user_id`) REFERENCES `r_user` (`id`))

最新文章

  1. MSSQL日志传送出现“LSN 太晚,无法应用到数据库”
  2. svn学习笔记(3)设置
  3. java面试
  4. ceph placement group状态总结
  5. oracle 备份和还原还有创建用户、表空间、授权
  6. 将SQL Azure数据库备份到本地SQL Server 2012
  7. 源码心德`Context`类
  8. speex 回声消除的用法
  9. spring4.1.3+springmvc+mybatis3.2.1整合
  10. Android底部导航栏——FrameLayout + RadioGroup
  11. Xpath语法格式整理
  12. Linux 常用性能工具简介
  13. TensorRT&Sample&Python[end_to_end_tensorflow_mnist]
  14. oracle select in超过1000条报错解决方法
  15. 20190422 T-SQL 触发器
  16. Docker小白从零入门实战
  17. 【刷题】BZOJ 4916 神犇和蒟蒻
  18. nginx 重写URL尾部斜杠
  19. [转]微信小程序之加载更多(分页加载)实例 —— 微信小程序实战系列(2)
  20. 为什么TCP连接需要三次握手分开需要四次握手?

热门文章

  1. Problem T: 零起点学算法15——交换变量
  2. EF需要注意的virtual,懒加载,还有1对n更新
  3. linux & windows 共享 smbd 部署
  4. 防止木马利用iframe框架来调用外域JS代码
  5. javascript快速入门6--Script标签与访问HTML页面
  6. renderdoc on android
  7. PHP Xdebug调试专题
  8. Yii2 关于时间格式的用法
  9. 【Hadoop】HDFS客户端开发示例
  10. Spark streaming + Kafka 流式数据处理,结果存储至MongoDB、Solr、Neo4j(自用)