热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

linux下用mysqldump来备份数据库

nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd

写在前面:
-----------------------------------------------------------------
有时候经常要把数据库转来转去,或者导入导出,以前记得命令,后来又忘记了,现在写出来备忘!
------------------------------------------------------------------
注意:MySQLdump比直接拷贝数据库文件夹速度要慢
但,直接复制文件夹不能100%转移到其它机子上用,我说的不是windows下 :)
#mysqldump db_name >/path/name.sql
上面的命令意思是把一个库导出到一个SQL文件. 当然,你直接在有ROOT密码的机子上执行以上命令一定会报错.所以,请用
#mysqldump db_name >/path/name.sql -uroot -p
这回会要求你输入密码,输入正确,找找/path下是不是有name.sql文件了?
数据库太大了,想压缩一下?好,用这个命令就行
#mysqldump db_name |gzip >/path/name.gz -uroot -p
想备份全部的库呢?
#mysqldump --all-databases  >/path/name.sql -uroot -p
#mysqldump --all-databases |gzip >/path/name.gz -uroot -p (很明显,这条命令是加压缩的意思)
只想备份一个单独或者几个表?
有时候数据库很大很大,整个库备份就不好管理,那就单独备份
#mysqldump db_name tab_name >/path/sqlname.sql -uroot -p
备份做好了.遇到问题的时候.怎么用备份恢复数据?
再简单不过了,
mysql db_name 注意:如果你想恢复的数据库是包含授权表的mysql数据库,你需要用--skip-grant-table选项运行服务器。否则,它会抱怨不能找到授权表。在你已经恢复表后,执行mysqladmin flush-privileges告诉服务器装载授权标并使用它们
恢复单个表
 恢复单个表较为复杂,如果你用一个由mysqldump生成的备份文件,并且它不包含你感兴趣的表的数据,你需要从相关行中提取它们并将它们用作mysql的输入。这是容易的部分。难的部分是从只运用于该表的更新日志中拉出片断。你会发觉mysql_find_rows实用程序对此很有帮助,它从更新日志中提取多行查询。


推荐阅读
author-avatar
mobiledu2502934573
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有