您当前的位置: 首页 >  sql

qq_34412985

暂无认证

  • 0浏览

    0关注

    1061博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

【MySQL】Navicat修改数据库名称

qq_34412985 发布时间:2019-09-05 16:48:32 ,浏览量:0

假设:有一个数据库,名称为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语句集合

from clipboard

先创建B库,否则会报错error7

选中sql语句集合(可以用shift+鼠标)>复制(ctrl+c)>粘贴到查询编辑器(ctrl+v)>运行

from clipboard然后刷新一下数据库B,就可以看见数据表了。刷新一下数据库A,发现里面已经没有数据表了

如果数据库名中包含.的话,执行上述步骤会提示错误,可以把数据库名用反单引号括起来,如: RENAME TABLE `tp5.1-20190213`.zht_article_cats to B.zht_article_cats;
关注
打赏
1653291990
查看更多评论
立即登录/注册

微信扫码登录

0.0445s