新闻动态

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

发布日期:2022-03-16 12:51 | 文章来源:站长之家

对数据库的表进行重命名可以使用以下原生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)

以上就是运用Python快速的对MySQL数据库进行重命名的详细内容,更多关于python 重命名MySQL数据库的资料请关注本站其它相关文章!

美国服务器租用

版权声明:本站文章来源标注为YINGSOO的内容版权均为本站所有,欢迎引用、转载,请保持原文完整并注明来源及原文链接。禁止复制或仿造本网站,禁止在非www.yingsoo.com所属的服务器上建立镜像,否则将依法追究法律责任。本站部分内容来源于网友推荐、互联网收集整理而来,仅供学习参考,不代表本站立场,如有内容涉嫌侵权,请联系alex-e#qq.com处理。

相关文章

实时开通

自选配置、实时开通

免备案

全球线路精选!

全天候客户服务

7x24全年不间断在线

专属顾问服务

1对1客户咨询顾问

在线
客服

在线客服:7*24小时在线

客服
热线

400-630-3752
7*24小时客服服务热线

关注
微信

关注官方微信
顶部