在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
MySQL数据库重命名的方法Innodb引擎的表如何改数据库名,MyISAM引擎又该如何操作。 如果表是MyISAM引擎可以直接去到数据库目录mv重命名文件夹就可以。 Innodb完全不行,会提示相关表不存在。 第一种方法:rename database 弃用了RENAME database old_db_name TO new_db_name 这个是5.1.7到5.1.23版本可以用的,但是官方不推荐,会有丢失数据的危险 第二种方法:mysqldump 备份1.创建需要改成新名的数据库。 mysqldump -uxxxx -pxxxx -h xxxx db_name > db_name_dump.SQL #备份 mysqldump -uroot -p123456 -h127.0.0.1 test > test.sql #备份 mysql -uxxxx -pxxxx -h xxxx -e “CREATE DATABASE new_db_name” mysql -uxxxx -pxxxx -h xxxx new_db_name < db_name_dump.SQL #还原 mysql -uxxxx -pxxxx -h xxxx -e “DROP DATABASE db_name” 第三种方法:快速且安全 遍历 rename table我这里就用一个脚本,很简单,相信大家都看的懂 #!/bin/bash # 假设将db_name数据库名改为new_db_name # MyISAM直接更改数据库目录下的文件即可 mysql_login=mysql -uroot -p123456 olddb=”db_name” newdb=”new_db_name” #$mysql_login -e “CREATE DATABASE $newdb $mysql_login -e 'create database if not exists $newdb' list_table=$($mysql_login -Nse "select table_name from information_schema.TABLES where TABLE_SCHEMA='$olddb'") for table in $list_table; do $mysql_login -e "rename table $olddb.$table to $newdb.$table" done; #$mysqlconn -e “DROP DATABASE $olddb” 这里用到了rename table,改表名的命令,但是如果新表名后面加数据库名,就会将老数据库的表移动到新的数据库,所以,这种方法即安全,又快速。 最后附rename用法 命令:rename table 原表名 to 新表名; 例如:在表MyClass名字更改为YouClass 当你执行 RENAME 时,你不能有任何锁定的表或活动的事务。你同样也必须有对原初表的 ALTER 和 DROP 权限,以及对新表的 CREATE 和 INSERT 权限。 如果在多表更名中,MySQL 遭遇到任何错误,它将对所有被更名的表进行倒退更名,将每件事物退回到最初状态。 Mysql:使用Navicat实现定时备份一、功能描述
|
请发表评论