如何修改MySQL数据库名称

如何修改MySQL数据库名称

比如数据库名称old_db想改名为new_db

MySQL修改数据库名称比较麻烦,不支持直接修改,需要通过其它方式间接达到修改数据库名称的目的。在 MySQL 5.1.23 之前的旧版本中,我们可以使用 RENAME DATABASE 来重命名数据库,但此后版本,因为安全考虑,删掉了这一条命令。

方法一:先导出数据,再导入数据

当数据库体积比较小时,最快的方法是使用mysqldump命令来创建整个数据库的转存副本,然后新建数据库,再把副本导入到新数据库中。

1.1 先创建新库:

create database new_db;

1.2 使用mysqldump导出数据:

mysqldump -uroot -p123456 --set-gtid-purged=OFF old_db > /tmp/old_db.sql仅是做普通的本机备份恢复时,可以添加--set-gtid-purged=OFF作用是在备份时候不出现GTID信息

1.3 导入数据到新库:

mysql -uroot -p123456 new_db < /tmp/old_db.sql

方法二:通过修改表名称,间接实现修改数据库名称

使用此方法实际上将所有表从一个数据库移动到另一个数据库,这实际上重命名了该数据库(MySQL没有单个语句的操作),移动后原始数据库继续存在,但是里面没有表。

==RENAME TABLE==:MySQL :: MySQL 5.7 Reference Manual :: 13.1.33 RENAME TABLE Statement

2.1 先创建新库:

create database new_db;

2.2 使用RENAME TABLE命令修改表名,将表移动到新的库里:

rename table old_db.tb to new_db.tb;

2.3 完成后删除旧库:

drop database old_db;

2.4 如何使用shell脚本来批量修改表名:

当库下表比较多的时候,用上面方法纯手动也不现实,好在linux下可以用shell脚本来批处理。附上一个shell脚本批量修改表名称。

#!/bin/bashmysql -uroot -p123456 -e 'create database if not exists new_db;'list_table=$(mysql -uroot -p123456 -Nse "select table_name from information_schema.TABLES where TABLE_SCHEMA='old_db'")for table in $list_tabledomysql -uroot -p123456 -e "rename table old_db.$table to new_db.$table"done

mysql登陆命令行参数

-e, —execute=name # 执行mysql的sql语句-N, —skip-column-names # 不显示列信息-s, —silent # 一行一行输出,中间有tab分隔

方案一:

备份db1里的t7表

[root@stu1 mysql]# mysqldump -u root -p123 db1 t7 > t7.sql

恢复db1里的t7表 [root@stu1 mysql]# mysql -u root -p123 db1 < t7.sql

方案二:

create table fund_netvalue_bak_2013_11_08 as select * from fund_netvalue

配餐:

备份db1里面的tb1和tb2的表 [root@stu12 mysql]# mysqldump db1 tb1 tb2 -u root -p123 > biao.sql

方案三:

SQL SELECT INTO 实例 - 制作备份复件

下面的例子会制作 "Persons" 表的备份复件:

SELECT * INTO Persons_backup

FROM Persons

IN 子句可用于向另一个数据库中拷贝表:

SELECT * INTO Persons IN 'Backup.mdb'

FROM Persons

如果我们希望拷贝某些域,可以在 SELECT 语句后列出这些域:

SELECT LastName,FirstName INTO Persons_backup

FROM Persons

SQL SELECT INTO 实例 - 被连接的表

从一个以上的表中选取数据也是可以做到的。

下面的例子会创建一个名为 "Persons_Order_Backup" 的新表,其中包含了从 Persons 和 Orders 两个表中取得的信息:

SELECT Persons.LastName,Orders.OrderNo INTO Persons_Order_Backup FROM Persons INNER JOIN Orders ON Persons.Id_P=Orders.Id_P

方案四:

INSERT INTO SELECT语句 语句形式为:Insert into Table2(field1,field2,...) select value1,value2,... from Table1 要求目标表Table2必须存在

✧ 相关推荐 ✧

爱吃油炸是人类天性,不怪你
cctv3直播365

爱吃油炸是人类天性,不怪你

📅 06-28 👁️ 1284
全新 Microsoft 365 高能登场
365完美体育app官网

全新 Microsoft 365 高能登场

📅 06-27 👁️ 2535
gta5线上跑车如何购买
365bet体育足球比分

gta5线上跑车如何购买

📅 07-03 👁️ 381