Serialization implementation InnoDB implements serialization in two ways. First, when the SELECT statement is in an explicit transaction block, such as executing case number 1 in Table 11-9, a LOCK_S lock will be applied. According to Table 11-6 (record lock transaction lock compatibility table), the LOCK_S lock excludes the write lock, so only concurrent read operations are allowed under the serialization isolation level, and concurrent writes are prohibited, thus achieving serializability. The corresponding code is as follows: ha_innobase::external_lock(...) {... if (lock_type != F_UNLCK) { /* MySQL is setting a new table lock */ ... if (trx->isolation_level == TRX_ISO_SERIALIZABLE //Serialization isolation level && m_prebuilt->select_lock_type == LOCK_NONE && thd_test_options(thd, OPTION_NOT_AUTOCOMMIT | OPTION_BEGIN)) { // and inside an explicit transaction block /* To get serializable execution, we let InnoDB conceptually add 'LOCK IN SHARE MODE' to all SELECTs which otherwise would have been consistent reads. An exception is consistent reads in the AUTOCOMMIT=1 mode: we know that they are read-only transactions, and they can be serialized also if performed as consistent reads. */ m_prebuilt->select_lock_type = LOCK_S; //Add read lock, i.e. 'LOCK IN SHARE MODE' m_prebuilt->stored_select_lock_type = LOCK_S; } //Otherwise, no lock (this is also very important) ... } else { TrxInInnoDB::end_stmt(trx); DEBUG_SYNC_C("ha_innobase_end_statement"); } ...} The second way, when the SELECT statement is not within an explicit transaction block, is to obtain the latest snapshot (at the beginning of the transaction) and then read the data. At this time, because the snapshot-based consistent read does not require locking, its locking situation corresponds to the situation corresponding to number 2 in Table 11-9. Table 11-9 Serialization isolation level locking illustrate: S0: In addition, for the FLUSH...WITH READ LOCK statement, a read lock LOCK_S is also required under the serialization isolation level. The code is as follows: ha_innobase::store_lock( ... /* Check for FLUSH TABLES ... WITH READ LOCK */ if (trx->isolation_level == TRX_ISO_SERIALIZABLE) { m_prebuilt->select_lock_type = LOCK_S; m_prebuilt->stored_select_lock_type = LOCK_S; } else { m_prebuilt->select_lock_type = LOCK_NONE; m_prebuilt->stored_select_lock_type = LOCK_NONE; } ... } Related to serialization is Summarize The above is the full content of this article. I hope that the content of this article can bring some help to your study or work. If you have any questions, you can leave a message to communicate. Thank you for your support of 123WORDPRESS.COM. You may also be interested in:
|
<<: Vue3.0 project construction and usage process
>>: Detailed explanation of dynamic link library calling C/C++ method in Python in Ubuntu
Recently, I have been working on a large-screen d...
This tag is not part of HTML3.2 and is only suppo...
Note: The system is Ubuntu 14.04LTS, a 32-bit ope...
Table of contents 1. Ant Design Vue 1. Official w...
1. Enable Prometheus telemetry data By default, t...
Table of contents 1 Node.js method of sending ema...
Preface It is said that if the people doing opera...
Mybatis paging plug-in pageHelper detailed explan...
1. Test environment name Version centos 7.6 docke...
This article uses an example to describe how to r...
####Management of input and output in the system#...
introduction Today I learned how to connect to th...
The implementation principle of chain programming...
1 / Copy the web project files directly to the we...
Table of contents 1. Nginx installation and start...