MySQL面试题:日志录入格式

接上篇《两道常见的MySQL面试题》,今天小树懒来给大家讲另一道面试题,关于MySQL binlog的几种日志录入格式。

一、MySQL BinLog日志的录入格式以及区别

Statement:将修改数据的所有sql都记录在binlog中。

好处:无需记录每行的变化,减少了binlog日志数量,节省了IO,提高了性能。(相对于row可以节省多少性能和日志数量,这取决于SQL应用程序的情况,通常同一记录修改或插入row格式所产生的日志数量比Statement所产生的日志数量少,但考虑到如果有条件的update操作,以及整个表格的删除,ROW格式会产生大量的日志,所以在考虑是否使用ROW格式日志时,应该根据实际情况,它所产生的日志数量会增加多少,以及IO性能问题。)

缺点:由于只记录执行句子,为了使这些句子能够在slave上正确运行,还必须记录每个句子执行时的一些相关信息,以确保所有句子都能在slave上得到与在master端执行时相同的结果。此外,mysql的复制,如一些特定的函数功能,如果slave能够与master保持一致,将会出现许多相关问题(如sleep()函数、last_insert_id()和user-definedfunctions(udf)。

使用以下函数的句子不能复制:

LOAD_FILE()

UUID()

USER()

FOUND_ROWS()

SYSDATE()(除非启动时启用-sysdate-is-now选项),否则INSERT..SELECT会产生比RBR更多的行级锁。

Row:

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值