运用Python快速的对MySQL数据库进行重命名

作者:一撸程猿 时间:2024-01-17 22:36:25 

目录
  • 常规思路

  • 更快捷的方法

    • 使用方法

对数据库的表进行重命名可以使用以下原生sql:


RENAME TABLE old_table TO new_table;  

窘境:但是MySQL并没有直接支持对数据库进行重命名

那么如何运用Python快速的对现有的数据库进行重命名呢?

比如项目初期,对数据库的命名(db_ridingroad)没有规划好,
然后在下面创建了大量的表和写入了大量的数据,现在需要对数据库的名字进行重命名为(db_news_website)

常规思路

下面的方法步骤较为繁琐


-- 数据库备份
mysqldump –u [UserName] –p[Password] –R [DB_Name] > [DB_Name].sql
-- 创建新数据库
create database [New_DB_Name];
-- 把备份的数据导入到新数据库
mysql –u [UserName] –p[Password] [New_DB_Name] < [DB_Name].sql
-- 删除旧数据库
drop database [DB_Name];

更快捷的方法

只需要执行下面这条命令即可


python rename_database.py old_db_name new_db_name

我们可以使用表重命名的方法,把表重命名到新的数据库之下。基本逻辑如下:

  1. 创建新数据库

  2. 获取旧数据库下所有的表名

  3. 把表重命名到新的数据库名下

  4. 删除旧数据库

下面使用Python代码去实现,主要代码(完整代码见文末):


def rename_db(old_name, new_name):
   """
   数据库重命名
   :param old_name: 原来的数据库名
   :param new_name: 新数据库名
   :return: 成功返回True, 失败返回False
   """
   # 获取所有的表名
   sql = """SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE table_schema=%s"""
   conn, cursor = context()
   try:
       # 创建新数据库名
       cursor.execute('create database if not exists {}'.format(new_name))

cursor.execute(sql, (old_name, ))
       results = cursor.fetchall()
       # 获取表明,循环处理放到新的数据库名下
       for r in results:
           tb = r['TABLE_NAME']
           rename_sql = """RENAME TABLE {}.{} to {}.{}""".format(old_name, tb, new_name, tb)
           cursor.execute(rename_sql)
       # 把旧数据库删掉
       cursor.execute('drop database {}'.format(old_name))
   except Exception as ex:
       conn.rollback()
       print("rename_db Exception: {},{}".format(sql, ex))
       return False
   else:
       # 如果没有发生异常,则提交事务
       conn.commit()
   finally:
       conn.close()
   return True

使用方法

1.安装PyMySQL


pip install PyMySQL

2.修改脚本中关于数据库账号配置信息部分


MYSQL_HOST = '127.0.0.1'
MYSQL_PORT = 3306
MYSQL_USER = 'ridingroad'
MYSQL_PASSWORD = 'xxxxyyyy'
MYSQL_DATABASE = 'db_ridingroad'

3.切换到脚本所在目录,执行以下命令即可(数据无价,请先mysqldump备份)


python rename_database.py old_db_name new_db_name

完整代码如下:


import sys
import pymysql

MYSQL_HOST = '127.0.0.1'
MYSQL_PORT = 3306
MYSQL_USER = 'ridingroad'
MYSQL_PASSWORD = 'xxxxyyyy'
MYSQL_DATABASE = 'db_ridingroad'
MYSQL_CHARSET = 'utf8'

def context(is_dict_cursor=True, database=MYSQL_DATABASE):
   """
   创建数据库连接, 数据以字典结构返回
   :param is_dict_cursor: 是否返回字典结构的数据
   :param database: 默认连接的数据库
   :return: 返回一个连接和一个浮标
   """
   try:
       config = {
           'host': MYSQL_HOST,
           'port': MYSQL_PORT,
           'user': MYSQL_USER,
           'password': MYSQL_PASSWORD,
           'database': database,
           'charset': MYSQL_CHARSET,
       }

conn = pymysql.connect(**config)
       if is_dict_cursor:
           cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
       else:
           cursor = conn.cursor()
       return conn, cursor
   except Exception as ex:
       print("connect database failed, {},{}".format(400, ex))
       raise Exception({'code': 400, 'msg': ex})

def rename_db(old_name, new_name):
   """
   数据库重命名
   :param old_name: 原来的数据库名
   :param new_name: 新数据库名
   :return: 成功返回True, 失败返回False
   """
   # 获取所有的表名
   sql = """SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE table_schema=%s"""
   conn, cursor = context()
   try:
       conn.begin()
       # 创建新数据库名
       cursor.execute('create database if not exists {}'.format(new_name))

cursor.execute(sql, (old_name, ))
       results = cursor.fetchall()
       # 获取表明,循环处理放到新的数据库名下
       for r in results:
           tb = r['TABLE_NAME']
           rename_sql = """RENAME TABLE {}.{} to {}.{}""".format(old_name, tb, new_name, tb)
           cursor.execute(rename_sql)
       # 把旧数据库删掉
       cursor.execute('drop database {}'.format(old_name))
   except Exception as ex:
       conn.rollback()
       print("rename_db Exception: {},{}".format(sql, ex))
       return False
   else:
       # 如果没有发生异常,则提交事务
       conn.commit()
   finally:
       conn.close()
   return True

if __name__ == '__main__':
   old_db = sys.argv[1]
   new_db = sys.argv[2]
   rename_db(old_name=old_db, new_name=new_db)

来源:https://juejin.cn/post/6970630548822130695

标签:python,重命名,MySQL
0
投稿

猜你喜欢

  • 详解MySQL中的分组查询与连接查询语句

    2024-01-17 16:32:19
  • Python使用multiprocessing创建进程的方法

    2022-08-03 14:09:21
  • go如何删除字符串中的部分字符

    2024-05-22 10:15:54
  • python 通过文件夹导入包的操作

    2023-03-10 12:48:24
  • 修改MySQL的数据库引擎为INNODB的方法

    2024-01-13 08:13:43
  • python tkinter canvas使用实例

    2021-07-11 23:49:50
  • asp 随机字符串函数

    2011-04-04 11:01:00
  • SQL Server 使用join all优化 or 查询速度

    2024-01-26 09:11:37
  • PyTorch 普通卷积和空洞卷积实例

    2021-01-06 16:42:57
  • 浅析JSONP技术原理及实现

    2024-05-28 15:41:10
  • JavaScript实现网页动态生成表格

    2024-04-16 09:24:00
  • Python爬取成语接龙类网站

    2022-04-09 07:29:58
  • Python数据分析之双色球统计两个红和蓝球哪组合比例高的方法

    2021-05-14 01:15:57
  • vue动态菜单、动态路由加载以及刷新踩坑实战

    2024-05-05 09:25:27
  • tensorflow输出权重值和偏差的方法

    2021-10-01 15:56:13
  • 解析Python扩展模块的加速方案

    2022-12-26 04:53:00
  • Go语言利用time.After实现超时控制的方法详解

    2024-04-26 17:21:50
  • Javascript脚本实现静态网页加密实例代码

    2024-04-19 11:04:30
  • ASP和MYSQL开发网站的注意事项

    2009-08-21 13:23:00
  • JS加载器如何动态加载外部js文件

    2024-04-16 08:47:06
  • asp之家 网络编程 m.aspxhome.com