对数据库的表进行重命名可以使用以下原生sql:
1
|
RENAME TABLE old_table TO new_table;
|
窘境:但是MySQL并没有直接支持对数据库进行重命名
那么如何运用Python快速的对现有的数据库进行重命名呢?
比如项目初期,对数据库的命名(db_ridingroad)没有规划好,
然后在下面创建了大量的表和写入了大量的数据,现在需要对数据库的名字进行重命名为(db_news_website)
常规思路
下面的方法步骤较为繁琐
1
2
3
4
5
6
7
8
|
-- 数据库备份
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];
|
更快捷的方法
只需要执行下面这条命令即可
1
|
python rename_database.py old_db_name new_db_name
|
我们可以使用表重命名的方法,把表重命名到新的数据库之下。基本逻辑如下:
- 创建新数据库
- 获取旧数据库下所有的表名
- 把表重命名到新的数据库名下
- 删除旧数据库
下面使用Python代码去实现,主要代码(完整代码见文末):
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
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
1
|
pip install PyMySQL
|
2.修改脚本中关于数据库账号配置信息部分
1
2
3
4
5
|
MYSQL_HOST = '127.0.0.1'
MYSQL_PORT = 3306
MYSQL_USER = 'ridingroad'
MYSQL_PASSWORD = 'xxxxyyyy'
MYSQL_DATABASE = 'db_ridingroad'
|
3.切换到脚本所在目录,执行以下命令即可(数据无价,请先mysqldump备份)
1
|
python rename_database.py old_db_name new_db_name
|
完整代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
|
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数据库的资料请关注服务器之家其它相关文章!
原文链接:https://juejin.cn/post/6970630548822130695