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.创建需要改成新名的数据库。
2.mysqldum 导出要改名的数据库
3.删除原来的旧库(确定是否真的需要)
当然这种方法虽然安全,但是如果数据量大,会比较耗时
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
mysql> rename table myclass to youclass;
当你执行 rename 时,你不能有任何锁定的表或活动的事务。你同样也必须有对原初表的 alter 和 drop 权限,以及对新表的 create 和 insert 权限。
如果在多表更名中,mysql 遭遇到任何错误,它将对所有被更名的表进行倒退更名,将每件事物退回到最初状态。
mysql:使用navicat实现定时备份
一、功能描述
需实现每天将数据库中数据备份,若出现问可及时还原备份;
二、实现步骤
打开navicat点击计划
点击新建批处理作业
选择要备份的数据库
点击选择并保存
点击上方工具条中设置计划任务
点击计划,点击新建,设置执行的时间
设置成功,数据默认备份在c:\users\administrator\documents\navicat\mysql\servers中;
在navicat中点击备份也可看到,点击选中备份文件即可还原备份;
认备份在c:\users\administrator\documents\navicat\mysql\servers中;
在navicat中点击备份也可看到,点击选中备份文件即可还原备份;
到此这篇关于mysql数据库重命名的快速且安全方法(3种)的文章就介绍到这了,更多相关mysql数据库重命名内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!