专栏首页Python异常处理:1215 - Cannot add foreign key constraint

异常处理:1215 - Cannot add foreign key constraint

  最近在做新生入学系统,学生表中包括新生的班级,专业等信息,班级,专业就需要和班级表,专业表进行关联,但是在添加外键的过程中却出现了“Cannot add foreign key constraint” 的问题,也就是不能添加外键约束,为什么就不能添加外键呢?

出现这个问题主要有三个原因:

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

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

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

     经过检查,前两种情况排除,但是两张表的存储引擎都不清楚,于是又百度了一些关于存储引擎的东西:

查询表的引擎:

a、show table status from db_name where name='table_name';

b、show create table table_name;

查询结果如图:

班级表的引擎:

学生表的引擎:

    果然是两张表的引擎不一致,那就修改成一样的呗

修改表的引擎:

alter table table_name engine=innodb;

    首先将basicclassentities表的ndbcluster引擎修改为InnoDB,但是又出现了新的错误:"1217 - Cannot delete or update a parent row: a foreign key constraint fails",于是尝试将freshstudententities表的引擎修改为ndbcluster,同样的问题。

    "1217 - Cannot delete or update a parent row: a foreign key constraint fails",这可能是MySQL在引擎中设置了foreign key关联,造成无法更新或删除数据。可以通过设置FOREIGN_KEY_CHECKS变量来避免这种情况:

SET FOREIGN_KEY_CHECKS = 0; 删除完成后设置 :SET FOREIGN_KEY_CHECKS = 1; 

     还是不能修改表的引擎,于是又继续探索mysql的各种引擎(http://www.cnblogs.com/ggjucheng/archive/2012/11/11/2765469.html),经过分析,由于ndbcluster和集群,分布式有关,自己的电脑上没有足够的权限,所以修改不了,只要将两张表的引擎都修改为InnoDB,就可以添加外键了。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 关于python的bottle框架跨域请求报错问题的处理

      在用python的bottle框架开发时,前端使用ajax跨域访问时,js代码老是进入不了success,而是进入了error,而返回的状态却是200。ur...

    用户1214487
  • vim显示行号、语法高亮、自动缩进的设置

    用户1214487
  • 数据库连接池,本地线程,上下文管理

    一、数据库连接池 flask中是没有ORM的,如果在flask里要连接数据库有两种方式 一:pymysql 二:SQLAlchemy 是pyth...

    用户1214487
  • JVM学习 : VM_Thread

    代码图片来自:https://blog.csdn.net/qq_31865983/article/details/103788358

    执生
  • 亚马逊前首席科学家:大数据价值体现在AI、BI、CI、DI

    无人机送货、阿法狗下棋、小冰和你谈场恋爱……人工智能领域的成果,一直是企业在大数据运用能力上的主要外在体现,但在亚马逊原首席科学家安德雷斯?韦思岸(Andre...

    灯塔大数据
  • Asp.NetCoreWebApi图片上传接口(二)集成IdentityServer4授权访问(附源码)

    上一篇文章中,给大家讲解了如何通过 Asp.Net Core Web Api实现图片上传的接口,具体的可以[点这里查看][https://www.cnblogs...

    依乐祝
  • 网页实时天气插件

    我写了一个Javascript的小程序,可以在网页上实时显示天气信息。效果如下: showWeatherInfo("CHXX0116"); 有兴趣的朋友,可以...

    ruanyf
  • Asp.NetCoreWebApi图片上传接口(二)集成IdentityServer4授权访问(附源码)

    上一篇文章中,给大家讲解了如何通过 Asp.Net Core Web Api实现图片上传的接口,具体的可以[点这里查看][https://www.cnblogs...

    依乐祝
  • Kotlin的高阶函数和常用高阶函数

    首先我们可以知道, forEach 是 Array 的扩展函数,然后参数是 action ,但是 action 不再像和我们以前Java那样传递的是一个对象,这...

    用户2802329
  • 详解React Native监听Android回退按键与程序化退出应用

    我们知道Android回退按键,会控制页面返回, 并且退出应用并非真正意义退出,仍在后台运行,所以在某些场景下需要监控android回退按键,那么在React ...

    砸漏

扫码关注云+社区

领取腾讯云代金券