这篇文章主要介绍“MySQL中begin后事务为什么不提交”,在日常操作中,相信很多人在MySQL中begin后事务为什么不提交问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL中begin后事务为什么不提交”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

今天顺便看了一下,主要流程就是跟踪为什么begin后事物不会提交,最后发现在:
MYSQL_BIN_LOG::commit 函数中包含这个判断

if(!cache_mngr->trx_cache.is_binlog_empty()&&ending_trans(thd,all)&&!trx_stuff_logged)

如果begin的话ending_trans(thd, all) 将会返回为false,也就不会调用 order_commit流程了。
那么其主要判断就是:

boolending_single_stmt_trans(THD*thd,constboolall){return(!all&&!thd->in_multi_stmt_transaction_mode());}

下面是源码注释和函数:

ReturnsTRUEifsessionisinamulti-statementtransactionmode.OPTION_NOT_AUTOCOMMIT:Whenautocommitisoff,amulti-statementtransactionisimplicitlystartedonthefirststatementafteraprevioustransactionhasbeenended.OPTION_BEGIN:Regardlessoftheautocommitstatus,amulti-statementtransactioncanbeexplicitlystartedwiththestatements"STARTTRANSACTION","BEGIN[WORK]","[COMMIT|ROLLBACK]ANDCHAIN",etc.Note:thisdoesn'ttellyouwhetheratransactionisactive.Asessioncanbeinmulti-statementtransactionmode,andyethavenoactivetransaction,e.g.,incaseof:set@@autocommit=0;set@a=3;<--thesestatementsdon'tsettransactionisolationlevelserializable;<--startanactiveflushtables;<--transactionI.e.fortheabovescenariothisfunctionreturnsTRUE,eventhoughnoactivetransactionhasbegun.@sain_active_multi_stmt_transaction()*/inlineboolin_multi_stmt_transaction_mode()const{returnvariables.option_bits&(OPTION_NOT_AUTOCOMMIT|OPTION_BEGIN);}

其实就是在判断是都option_bits的对应位上为1。因此简单了我们就看看什么时候设置OPTION_BEGIN位就好了。

实际上是函数trans_begin设置的下面是这段代码:

thd->variables.option_bits|=OPTION_BEGIN;thd->server_status|=SERVER_STATUS_IN_TRANS;if(thd->tx_read_only)thd->server_status|=SERVER_STATUS_IN_TRANS_READONLY;DBUG_PRINT("info",("settingSERVER_STATUS_IN_TRANS"));if(tst)tst->add_trx_state(thd,TX_EXPLICIT);/*ha_start_consistent_snapshot()reliesonOPTION_BEGINflagset.*/if(flags&MYSQL_START_TRANS_OPT_WITH_CONS_SNAPSHOT){if(tst)tst->add_trx_state(thd,TX_WITH_SNAPSHOT);res=ha_start_consistent_snapshot(thd);}

实际上就是在MySQL层设置一些标示,如果是 START TRANSACTION WITH CONSISTENT SNAPSHOT 还会开启一个一致性快照,就是一个readview。一旦设置了个标示将会不自动提交了。

到此,关于“MySQL中begin后事务为什么不提交”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!