MySQL学习之外键的图文详解


本文摘自PHP中文网,作者黄舟,侵删。

1、比方现在有两张表“分类表”和“商品表”,为了表明商品属于哪个分类,通常我们将在商品表上添加一列,用于存放分类cid的信息,此列称为:外键。

此时分类表category称为主表,cid称为主键;商品表products称为从表,category_id称为外键。

外键特点:1)从表外键的值是对主表主键的引用

     2)从表外键类型必须与主表主键一致。

使用外键的目的:保证数据的完整性

2、首先在命令提示符内创建一个数据库web09,并创建两张表category和product,语句如下:

分别插入多条数据

1

2

eg.insert into category(cid,cname) values('c001','家电');

insert into product(pid,pname,price,category_id) values('p001','联想','5000','c001');

显示如下:

3、声明外键约束

语法:alter table 从表 add [constraint] [外键名称] foreign key (从表外键字段名) references 主表 (主表的主键);

[外键名称]用于删除外键约束的,一般建议"_fk"结尾

约束声明后,如果我想删除category表中cid=c003的数据,删除不了

4、解除约束

语法:alter table 从表 drop foreign key 外键名称

继续删除category表中cid=c003的数据,可以删除

注意:从表外键不能添加主表中不存在的记录

   主表不能删除从表中已经引用的记录。

5、一对多建表原则:

6、多对多建表原则:

以上就是MySQL学习之外键的图文详解的详细内容,更多文章请关注木庄网络博客!!

相关阅读 >>

mysql如何插入多条数据?

mysql字段处理方法

mysql5.1如何安装?

详解高性能mysql主从架构的复制原理及配置

如何理解mysql中的数据类型概念?

mysql的comment怎么用

mysql数据类型有哪些?mysql数据类型详解

深入了解sql注入

mysql导入大批量数据出现mysql server has gone away的解决方法

mysql访问控制系统入门

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...