删除MySQL中所有表的外键的两种方法

 更新时间:2024年05月28日 10:56:15   作者:梁云亮  
这篇文章主要介绍了删除MySQL中所有表的外键的两种方法,文中通过代码示例讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下

方法一:

原理
查询schema中所有外键名称然后拼接生成删除语句

第一步:

SELECT CONCAT('ALTER TABLE ',TABLE_SCHEMA,'.',TABLE_NAME,' DROP FOREIGN KEY ',CONSTRAINT_NAME,' ;') 
FROM information_schema.TABLE_CONSTRAINTS c 
WHERE c.TABLE_SCHEMA='数据库名' AND c.CONSTRAINT_TYPE='FOREIGN KEY';

第二步:

将执行第一步得到的SQL语句拷贝到命令行中执行,就会删除所有的外键了。

方法二

-- 禁用外键约束
SET FOREIGN_KEY_CHECKS = 0
-- 启用外键约束
SET FOREIGN_KEY_CHECKS = 1;

由于FOREIGN_KEY_CHECKS是基于session的,当关闭了session重新建立连接,这个变量就会恢复默认值,也就是开启外键约束,当然我们也可以全局的FOREIGN_KEY_CHECKS变量。

SET GLOBAL FOREIGN_KEY_CHECKS = 0;
或者:
SET @@GLOBAL.FOREIGN_KEY_CHECKS = 0;

修改完成后,可以使用下面命令查看修改后的结果:

SELECT @@FOREIGN_KEY_CHECKS;

到此这篇关于删除MySQL中所有表的外键的两种方法的文章就介绍到这了,更多相关删除MySQL所有外键内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL中存储的数据查询的时候如何区分大小写

    MySQL中存储的数据查询的时候如何区分大小写

    这篇文章主要介绍了MySQL中存储的数据查询的时候如何区分大小写问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • mysql5.5中文乱码问题解决的有用方法

    mysql5.5中文乱码问题解决的有用方法

    在使用MYSQL时遇到中文乱码的问题,表现为插入数据后查询时输出为??(乱码),下面这篇文章主要给大家介绍了关于mysql5.5中文乱码问题解决的有用方法,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2022-05-05
  • 如何查看自己电脑MySQL是否安装成功

    如何查看自己电脑MySQL是否安装成功

    执行mysql程序后我们需要对mysql数据库进行验证,检查其是否安装成功,这篇文章主要给大家介绍了关于如何查看自己电脑MySQL是否安装成功的相关资料,需要的朋友可以参考下
    2023-11-11
  • mysql增加新用户无法登陆解决方法

    mysql增加新用户无法登陆解决方法

    在使用mysql增加新用户之后,发现新增的用户无法登陆,一时束手无策,网上搜集整理了一下,晒出来和大家分享一下,希望可以帮助你们
    2012-11-11
  • Mysql使用聚合函数时需要注意事项

    Mysql使用聚合函数时需要注意事项

    聚合函数作用于一组数据,并对一组数据返回一个值,常见的聚合函数:SUM()、MAX()、MIN()、AVG()、COUNT(),这篇文章主要介绍了Mysql使用聚合函数时需要注意事项,需要的朋友可以参考下
    2024-08-08
  • SQLServer注释快捷键操作

    SQLServer注释快捷键操作

    这篇文章主要介绍了SQLServer注释快捷键操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • Mysql主键和唯一键的区别点总结

    Mysql主键和唯一键的区别点总结

    在本篇文章中小编给大家分享了关于Mysql主键和唯一键的区别,有兴趣的朋友们学习下吧。
    2019-02-02
  • 一键搭建MYSQL主从,轻松应对数据备份与恢复

    一键搭建MYSQL主从,轻松应对数据备份与恢复

    MYSQL主从是一种常见的数据库架构,它可以提高数据库的可用性和性能,在主从架构中,主数据库负责处理写操作,而从数据库负责处理读操作,当主数据库发生故障时,从数据库可以接管并继续提供服务,从而实现高可用性,需要的朋友可以参考下
    2023-10-10
  • ubuntu下mysql版本升级到5.7

    ubuntu下mysql版本升级到5.7

    这篇文章主要为大家详细介绍了ubuntu下mysql版本升级到5.7的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • MySQL Replication中的并行复制示例详解

    MySQL Replication中的并行复制示例详解

    MySQL在5.6版本之前,主从复制的从节点上有两个线程,分别是I/O线程和SQL线程,今天通过本文给大家介绍MySQL Replication中的并行复制示例详解,感兴趣的朋友一起看看吧
    2022-07-07

最新评论