假设:有一个数据库,名称为A,需要修改为B。 在Navicat中不可以按F2修改数据库的名称,我们必须新建一个库,命名为B。 下面4种方式都可以实现目标。如果数据库中有远程表和权限设置,推荐使用第四种方式。函数可以直接复制, 视图?
1、如果数据库A中的表和设置比较简单,直接复制数据库A中所有表,粘贴到数据库B即可。
2、在A数据库上右击 –> 转储SQL文件 –> 结构和数据 ; 在B数据库上右击 –> 运行SQL文件。
执行速度:最慢。
3、选择菜单栏:工具 –> 数据传输(源库为A,目标库为B) –> 开始,传输完成后,刷新数据库B。
如果数据库A中存在远程表的话,操作会报错,错误信息为:
[Err] [Dtf] 1432 - server name: '' doesn't exist!
因此,你需要先将数据库中所有远程表的DDL语句复制到一个txt文件中,再删除数据库中的所有远程表。再次执行本操作。最后,将保存在txt文件中的所有DDL语句在B库上执行一遍即可。实现原理:复制粘贴。执行速度:中等。
4、重命名数据库A中的所有表,两个库需在同一服务器。(推荐)
执行下面的SQL语句,查询结果为重命名表的sql脚本集合:
select CONCAT('RENAME TABLE ',TABLE_SCHEMA,'.',TABLE_NAME,' to ', 'B.',TABLE_NAME,';')
from information_schema.`TABLES` where TABLE_SCHEMA = 'A';
复制所有结果行,将其作为sql脚本执行。执行速度:最快。
第4种方法步骤如下图:
查询>新建查询>粘贴上述代码>点运行>得到结果1的sql语句集合
先创建B库,否则会报错error7
选中sql语句集合(可以用shift+鼠标)>复制(ctrl+c)>粘贴到查询编辑器(ctrl+v)>运行
然后刷新一下数据库B,就可以看见数据表了。刷新一下数据库A,发现里面已经没有数据表了
如果数据库名中包含.的话,执行上述步骤会提示错误,可以把数据库名用反单引号括起来,如:
RENAME TABLE `tp5.1-20190213`.zht_article_cats to B.zht_article_cats;