设为首页 收藏本站
查看: 398|回复: 0

[经验分享] MySQL学习笔记——mysqldump工具的基本用法

[复制链接]

尚未签到

发表于 2016-10-17 06:24:26 | 显示全部楼层 |阅读模式
  
MySQL数据库备份按照格式可以分为两大类:
文本格式的备份:这类备份是通过使用mysqldump程序把数据表内容写到转储文件二得到的,内容主要是由CREATE TABLEINSERT两种SQL语句构成,把转储文件重新加载到MySQL服务器上就可以恢复有关的数据表。
二进制备份:这类备份是通过直接复制那些包含着数据表内容的文件而得到的。制作这类备份的具体办法有许多种,诸如mysqlhotcopycptarrsync之类的程序都可以用来数据库制作二进制备份。
 
mysqldump程序生成的内容是SQL语句的文本文件,很方面移植,平时用的就是这种方法。
 
mysqldump程序有许多选项。一下几个选项是比较常用的。
①、通常在mysqldump命令行给出一个数据库名,然后可以在它后面再选择性地给出几个数据表名。如果想一次转储多个数据库,就要使用--databases选项。mysqldump将把你在命令行上给出的名字全部解释为数据库名,并依次转储这些数据库里的所有数据表。如果想转储所有的数据库,可以使用--all-databases选项,此时不需要给出任何数据库名或数据表名参数。这两个参数会在每个数据库输出前插入必要的CREATE DATABASE IF NOT EXISTSUSE语句。
 
②、在默认情况下,mysqldump程序将同时备份数据表的结构(CREATE TABLE语句)和数据表的内容(INSERT语句)。如果只想备份其中的一种,可以使用--no-create-info--no-data选项。
 
③、可以使用--opt选择进行备份优化。默认是启动的,如果不需要,可以shiyong--skip-opt选项禁用。
--opt选项会把正在备份的数据表全部锁定,不让其他人修改。因此在确认无用户需要操作数据库的时候进行备份。
--opt对更新数据表很有用。因为--opt选项自动启动--add-drop-table选项,后者将使mysqldump备份文件里每条CREATETABLE语句之爱情你加上一条DROP TABLE IF EXISTS语句。这样你在加载的时候,如果数据表已经存在,也不会发生错误。
 
④、--opt选项的效果之一是它将启动--extended-insert选项,后者将使mysqldump程序生成可以一次插入多个数据行的INSERT语句。如果想让mysqldump程序生成的INSERT语句每条只插入一个数据行,可以使用--skip-extended-insert选项。
 
⑤、在备份InnoDBFalcon数据表的时候,最好使用--single-transaction选项把备份操作放在一个事务里执行,这可以确保得到一个稳定的备份。
 
⑥、如果数据库包含着存储例程、触发器和事件,可以使用--routing--triggers--events选项明确地把它们包括到备份文件里。注意,这个三个选项分别开始于MYSQL5.0135.0.115.1.8版本,如果是在此之前的版本,不支持。同时这几个选项还各有一个--skip形式(例如--skip-triggers)用来禁止备份指定的对象。
在默认是情况下,只有触发器将被包括在备份输入里,存储例程和事件不进入存储。
 
 
几个常用用例:
1.导出整个数据库
 mysqldump -u 用户名 -p 数据库名 > 导出的文件名   
 mysqldump -u wcnc -p smgp_apps_wcnc >wcnc.sql
2.导出一个表
 mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名
 mysqldump -u wcnc -p smgp_apps_wcnc users>wcnc_users.sql
3.导出一个数据库结构
  mysqldump -u wcnc -p -d --add-drop-tablesmgp_apps_wcnc >d:\wcnc_db.sql
 -d 没有数据 --add-drop-table 在每个create语句之前增加一个droptable
4.导入数据库
  常用source 命令
  进入mysql数据库控制台,
  如mysql -u root -p
 
  mysql>use 数据库
  然后使用source命令,后面参数为脚本文件(如这里用到的.sql)
  mysql>source d:\wcnc_db.sql

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-287079-1-1.html 上篇帖子: mysql中操作系统级别错误代码与其含义 下篇帖子: Hibernate + proxool 初级配置(Hibernate3+MySql 8小时)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表