MySQL中如何设置外键

下面我将以举例的方式说明,作者能力有限,欢迎指正和补充。也欢迎和我交流探讨~

一、环境

Windows操作系统,MySQL 5.7

二、使用工具

Navicat

三、前提知识

1.什么是主键

Primary key,唯一标识一个实体,取值非空唯一。比如,一个人的身份证号。

2.什么是外键

Foreign key, 本关系表中的属性的属性值需要参照另外一个表中主键的属性值而存在,可为空也可不为空。

四、实例

目前有一个名为shopping的数据库,里面有如下几张表:
category:种类表
goods :商品表
images: 图片表
trolley: 购物车
users:用户表
users_address:收货地址
MySQL中如何设置外键_第1张图片

1.首先理清这几张表的联系

补充说明:
1. 绿色框为各表主键
2. 红色箭头表示每两张表之间的主键与外键相对应(从本表外键指向其他表的主键)。
**3.**我只给出了部分主要值。
比如 trolley 表中的 users_id 指向 users 表中的users_id 。
MySQL中如何设置外键_第2张图片

2. 设置外键

用户表收货地址表为例, 这两个表中,外键为收货地址表中的 users_id, 所以在收货地址表建立外键。

2.1 收货地址表 users_address 单击,右键 —>设计表,用户表 users 以同样方法打开。

MySQL中如何设置外键_第3张图片

2.2 检查以下要素

(该部分划重点!!!大部分情况下添加外键失败是某个条件没满足导致的~)
1. users_id 在users 表中是否设为主键,users_address 中是否有users_id 这一项(即 是否两表中的项相互对应)?
2. 两表中的 users_id 的类型是否设置成一样的?
3. 两表中的 users_id 的长度是否设置成一样的?
4. 两表中的 users_id 是否设置成无符号?
MySQL中如何设置外键_第4张图片
MySQL中如何设置外键_第5张图片

2.3 如果检查完无误,记得先保存,然后刷新一下(表 右键 —>刷新)。建议:刷新后先关掉表再重新打开表。

MySQL中如何设置外键_第6张图片

2.4 users_address 表点击 外键,添加外键(这时参考模式会自动变成数据库名),字段选择之前确立好的外键 users_id, 然后确定。参考表选 主键为 users_id 的表,即 users 表。参考字段即主键users_id 。“删除时,更新时” 这两项一般不用管,然后点击保存。

MySQL中如何设置外键_第7张图片
MySQL中如何设置外键_第8张图片

2.5 设置完后点击保存 ,出现如下样式就是建立成功(没报错就是就建成功了)。

MySQL中如何设置外键_第9张图片

2.6 如果报错,参见2.2。

你可能感兴趣的:(MySQL)