MySQL中如何设置外键

30次阅读

共计 908 个字符,预计需要花费 3 分钟才能阅读完成。

由于数据表太多,想搞 ER 图来看看,方便以后维护

一、环境
Windows 操作系统,MySQL 5.7

二、使用工具
Navicat

三、前提知识
1. 什么是主键
Primary key,唯一标识一个实体,取值非空唯一。比如,一个人的身份证号。

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

四、实例
目前有一个名为 shopping 的数据库,里面有如下几张表:
category:种类表
goods:商品表
images:图片表
trolley:购物车
users:用户表
users_address:收货地址

1. 首先理清这几张表的联系
补充说明:

  1. 绿色框为各表主键
  2. 红色箭头表示每两张表之间的主键与外键相对应(从本表外键指向其他表的主键)。

3.我只给出了部分主要值。
比如 trolley 表中的 users_id 指向 users 表中的 users_id。

  1. 设置外键

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

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

2.2 检查以下要素
(该部分划重点!!!大部分情况下添加外键失败是某个条件没满足导致的~)

  1. users_id 在 users 表中是否设为主键,users_address 中是否有 users_id 这一项(即 是否两表中的项相互对应)?
  2. 两表中的 users_id 的类型是否设置成一样的?
  3. 两表中的 users_id 的长度是否设置成一样的?
  4. 两表中的 users_id 是否设置成无符号?

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

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

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

2.6 如果报错,参见 2.2。

正文完
 0