解决 1215 - Cannot add foreign key constraint

解决 1215 - Cannot add foreign key constraint

描述

今天在创建表单的时候添加外键约束,点击保存的时候出现报错1215 - Cannot add foreign key constraint

在这里插入图片描述

分析

出现这种情况报错主要有三个原因

  1. 外键对应的字段数据类型不一致

  2. 设置外键时“删除时”设置为“SET NULL”

  3. 两张表的存储引擎不一致

我在创建user表和role表的时候确定设置了存储引擎都是Innodb,这里排除了第三个可能。

同时我在设置外键删除时没有设置“SET NULL”。
那么出现错误的可能就是第一种:外键对应的字段数据类型不一致

解决

查询中间表的user_id和role_id发现类型是int,而user表和role表的对应字段为varchar类型,修改为统一varchar类型后成功解决问题。

Memorial Day is 512 days
I miss you
xiaokeai

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值