使用Python批量删除MySQL数据库的全部外键

 更新时间:2024年04月25日 11:27:00   作者:我向往自由  
这篇文章主要为大家详细介绍了如何使用Python批量删除MySQL数据库的全部外键,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下

我先说下场景,昨天因为我们使用了Java工作流框架flowable,它自动生成了许多工作流相关的表,但是这些表都有外键关联,如果单纯的使用sql语句去一个一个的删除外键,那会非常麻烦,所以我写了一个Python脚本来进行批量删除。

前提是你要有个Python环境...

先安装mysql驱动依赖:

pip install mysql-connector-python

因为代码非常简单,所以直接把代码粘出来,改下你mysql的连接信息,直接右键运行即可。

import mysql.connector
 
def delete_foreign_keys(host, port, user, password, database):
    try:
        # 连接到数据库
        conn = mysql.connector.connect(
            host=host,
            port=port,
            user=user,
            password=password,
            database=database
        )
 
        cursor = conn.cursor()
 
        # 查询外键约束
        cursor.execute("""
            SELECT 
                CONSTRAINT_NAME,
                TABLE_NAME
            FROM
                INFORMATION_SCHEMA.REFERENTIAL_CONSTRAINTS
            WHERE
                UNIQUE_CONSTRAINT_SCHEMA = %s;
        """, (database,))
 
        foreign_keys = cursor.fetchall()
 
        # 生成删除外键约束的 SQL 语句并执行
        for fk in foreign_keys:
            constraint_name, table_name = fk
            cursor.execute(f"ALTER TABLE {table_name} DROP FOREIGN KEY {constraint_name};")
            print(f"Deleted foreign key constraint {constraint_name} from table {table_name}")
 
        conn.commit()
        print("All foreign key constraints deleted successfully!")
 
    except mysql.connector.Error as error:
        print("Error while connecting to MySQL", error)
 
    finally:
        if conn.is_connected():
            cursor.close()
            conn.close()
            print("MySQL connection is closed")
 
# 设置数据库连接参数
host = '127.0.0.1'
port = 3306  # MySQL 默认端口号
user = 'root'
password = 'root'
database = 'mydatabase'
 
# 调用函数删除外键约束
delete_foreign_keys(host, port, user, password, database)

到此这篇关于使用Python批量删除MySQL数据库的全部外键的文章就介绍到这了,更多相关Python删除MySQL外键内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • python使用ddt过程中遇到的问题及解决方案【推荐】

    python使用ddt过程中遇到的问题及解决方案【推荐】

    在使用DDT数据驱动+HTMLTestRunner输出测试报告时遇到过2个问题,没个问题都很奇葩,下面小编通过本文给大家分享python使用ddt过程中遇到的问题及解决方案,需要的朋友参考下吧
    2018-10-10
  • macOS M1(AppleSilicon) 安装TensorFlow环境

    macOS M1(AppleSilicon) 安装TensorFlow环境

    苹果为M1芯片的Mac提供了TensorFlow的支持,本文主要介绍了如何给使用M1芯片的macOS安装TensorFlow的环境,感兴趣的可以了解一下
    2021-08-08
  • PyCharm中如何切换Python版本

    PyCharm中如何切换Python版本

    这篇文章主要介绍了PyCharm中如何切换Python版本问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • Python 日期区间处理 (本周本月上周上月...)

    Python 日期区间处理 (本周本月上周上月...)

    这篇文章主要介绍了Python 日期区间处理 (本周本月上周上月...),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-08-08
  • python数据容器总结示例详解

    python数据容器总结示例详解

    本文主要介绍了Python中的数据容器,包括列表、元组、字符串、集合和字典,每种数据容器都有其独特的定义、操作方法和特点,感兴趣的朋友跟随小编一起看看吧
    2025-11-11
  • Python实现微信小程序自动操作工具

    Python实现微信小程序自动操作工具

    这篇文章主要为大家详细介绍了如何利用Python实现微信小程序自动化操作的小工具,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下
    2023-01-01
  • Python 的内置字符串方法小结

    Python 的内置字符串方法小结

    本文主要给大家介绍了下Python的一些内置字符串的方法,包括概览,字符串大小写转换,字符串格式输出,字符串搜索定位与替换,字符串的联合与分割,字符串条件判断,字符串编码
    2016-03-03
  • Python执行ping操作的简单方法

    Python执行ping操作的简单方法

    本文主要介绍了Python执行ping操作的简单方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-02-02
  • Python进行数据提取的方法总结

    Python进行数据提取的方法总结

    数据提取是分析师日常工作中经常遇到的需求。如某个用户的贷款金额,某个月或季度的利息总收入,某个特定时间段的贷款金额和笔数,大于5000元的贷款数量等等。本篇文章介绍如何通过python按特定的维度或条件对数据进行提取,完成数据提取需求。
    2016-08-08
  • Python中logging模块的用法实例

    Python中logging模块的用法实例

    这篇文章主要介绍了Python中logging模块的用法实例,以实例形式介绍了日志模块logging的用法,具有一定的实用价值,需要的朋友可以参考下
    2014-09-09

最新评论