MySQL OCP888题解055-mysqldump的性能选项

1、原题

1.1、英文原题

You have a server that has very limited memory but has a very large table. You will use mysqldump to back up this table.
Which option will ensure mysqldump will process a row at a time instead of buffering a set of rows?
A、–quick
B、–skip-buffer
C、–single-transaction
D、–tab

1.2、中文翻译

您的服务器内存非常有限,但表非常大。您将使用mysqldump来备份此表。
哪个选项可以确保mysqldump一次处理一行,而不是缓冲一组行?
A、–quick
B、–skip-buffer
C、–single-transaction
D、–tab

1.3、答案

A

2、题目解析

2.1、题干解析

本题主要考察mysqldump跟性能有关的选项。

2.2、选项解析

  1. –quick选项可以强制mysqldump每次只取一行,从而降低对缓冲区内存大小的要求,所以选项A正确。
  2. mysqldump没有skip-buffer这个选项,所以选项B错误。
  3. –single-transaction只对InnoDB表有效,会在REPEATABLE READ事务级别下发出一条START TRANSACTION SQL语句,从而保证在一致且非阻塞的状态下转储数据。要转储大表,可将–single-transaction选项与–quick选项结合使用。所以选项C错误。
  4. –tab选项的作用是将表定义和表数据分开转储。所以选项D错误。

3、知识点

3.1、知识点1:mysqldump的性能选项

对于大型数据集,恢复操作(处理转储文件中的INSERT语句)是最耗时的部分。mysqldump有如下一些选型用于解决恢复操作时的性能问题:

官方参考文档

3.2、知识点2:mysqldump的–single-transaction选项

  • 这个选项将事务隔离模式设置为REPEATABLE READ,并在转储数据之前向服务器发送一条START TRANSACTION SQL语句,这样就会获得数据库的一致状态,而不会阻塞任何应用程序。它只对InnoDB表有用。
  • 当–single-transaction选项进行转储时,其他连接不应该使用以下语句:alter table, create table, drop table, rename table, truncate table。否则会导致mysqldump执行SELECT获得不正确的内容或失败。
  • –single-transaction选项和–lock-tables选项是相互排斥的,因为LOCK TABLES会导致任何未决的事务被隐式提交。
  • 要转储大表,可将–single-transaction选项与–quick选项结合使用。

官方参考文档

3.3、知识点3:mysqldump的–tab选项

–tab选项会让表的数据和定义文件分开转储。包括一个tbl_name.sql文件和tbl_name.txt文件,tbl_name.sql文件包含创建该表的CREATE TABLE语句,tbl_name.txt文件是以制表符分隔的文本格式的数据文件。
默认情况下,.txt数据文件的格式是在列值之间使用制表符,在每一行的末尾使用换行符。格式可以用 --fields-xxx 和 --lines-terminated-by 选项明确指定。

官方参考文档

4、总结

  1. mysqldump的–quick选项会强制让mysqldump每次只取一行数据而不是多行,从而降低对缓冲区内存大小的要求。
  2. mysqldump的–single-transaction选项只对InnoDB表有效,会在转储前发出开启事务的指令,从而在一致且非阻塞的状态下转储。–single-transaction选项和–lock-tables选项是互斥的,推荐使用–single-transaction选项。
  3. mysqldump的–tab选项会将表的定义语句和数据分开转储。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值