使用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)

相关推荐

  1. 使用Python实现批量删除MYSQL数据库全部

    2024-04-25 10:36:05       31 阅读
  2. MySQLMySQL和级联删除

    2024-04-25 10:36:05       37 阅读
  3. 36.MYSQL(foreign key)

    2024-04-25 10:36:05       53 阅读
  4. Oracle约束三种删除行为

    2024-04-25 10:36:05       25 阅读
  5. MYSQL增加

    2024-04-25 10:36:05       31 阅读
  6. MYSQL 批量删除连接

    2024-04-25 10:36:05       32 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-25 10:36:05       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-25 10:36:05       106 阅读
  3. 在Django里面运行非项目文件

    2024-04-25 10:36:05       87 阅读
  4. Python语言-面向对象

    2024-04-25 10:36:05       96 阅读

热门阅读

  1. Node.js中fs模块实现配置文件的读写

    2024-04-25 10:36:05       37 阅读
  2. 微前端通信机制及其实现

    2024-04-25 10:36:05       30 阅读
  3. css 动画基础知识和案例

    2024-04-25 10:36:05       34 阅读
  4. Mysql 的char 和varchar的的区别

    2024-04-25 10:36:05       33 阅读
  5. CSS基础——2.CSS选择器

    2024-04-25 10:36:05       32 阅读
  6. 机器学习之模糊聚类(Fuzzy Clustering)附代码

    2024-04-25 10:36:05       35 阅读
  7. 网络安全学习路线推荐

    2024-04-25 10:36:05       38 阅读