如何修改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`==:[https://dev.mysql.com/doc/refman/5.7/en/rename-table.html](https://dev.mysql.com/doc/refman/5.7/en/rename-table.html)
#### 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/bash
mysql -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_table
do
mysql -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分隔*
#### 因为有悔,所以披星戴月;因为有梦,所以奋不顾身! 个人博客首发:`easydb.net` 微信公众号:`easydb` 关注我,不走丢!
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/69982604/viewspace-2724260/,如需转载,请注明出处,否则将追究法律责任。