手机版
你好,游客 登录 注册 搜索
背景:
阅读新闻

MySQL 5.7下修改数据库名

[日期:2017-11-19] 来源:Linux社区  作者:甲骨文技术支持 [字体: ]

今天接到需求说需要把MySQL 5.7数据库的名字从A改为B,查了下A数据库下有不到200张表,也不是很大,要是用导入导出也可以,就是还是会慢,时间宝贵啊,用的时间越少越好。

有个rename table命令,写个脚本主要用它来实现需求

  1. #!/bin/bash
  2. #先判断新数据库是否存在,要是不存在就创建。
  3. #列出老数据库下都有那些表,其中N和s参数起到的作用是格式化,有点类似于Oracle下sqlplus里的pagesize
  4. #用for循环来rename。
  5. mysql -uroot -pxxxxDB2017# -e 'create database if not exists cus_0042'
  6. list_table=$(mysql -uroot -pxxxxDB2017# -Nse "select table_name from information_schema.TABLES where TABLE_SCHEMA='old_databases'")
  7. for table in $list_table
  8. do
  9.     mysql -uroot -pxxxxDB2017# -e "rename table old_databases.$table to cus_0042.$table"
  10. done

执行成功后,old_databases下就空了,可是删除了。

假如是myisam的存储引擎,直接在数据目录下mv就行。

本文永久更新链接地址http://www.linuxidc.com/Linux/2017-11/148725.htm

linux
相关资讯       MySQL修改数据库名 
本文评论   查看全部评论 (0)
表情: 表情 姓名: 字数

       

评论声明
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款