接上篇《两道常见的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: