zoukankan      html  css  js  c++  java
  • 如何修改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 TABLEhttps://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 关注我,不走丢!

  • 相关阅读:
    execute,executeQuery,executeUpdate的区别是什么?
    JDBC访问数据的基本步骤是什么
    什么是JDBC,在上面时候会用到它
    Java 为每个原始类型提供了哪些包装类型:
    Java 为每个原始类型提供了哪些包装类型:
    JDBC访问数据库的基本步骤是什么?
    String 类的常用方法都有那些?
    == 和 equals 的区别是什么
    查询所有课程成绩小于60分的同学的学号、姓名;
    什么是JDBC的最佳实践?
  • 原文地址:https://www.cnblogs.com/easydb/p/13733284.html
Copyright © 2011-2022 走看看