本篇內(nèi)容主要講解“怎么理解MySQL中Innodb DB_ROLL_PTR指針”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“怎么理解MySQL中Innodb DB_ROLL_PTR指針”吧!

創(chuàng)新互聯(lián)建站專注于龍沙企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站開(kāi)發(fā),商城系統(tǒng)網(wǎng)站開(kāi)發(fā)。龍沙網(wǎng)站建設(shè)公司,為龍沙等地區(qū)提供建站服務(wù)。全流程定制制作,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)建站專業(yè)和態(tài)度為您提供的服務(wù)
我們知道每一條記錄在聚集索引上都有如下的分布:
rowid(主鍵)+DB_TRX_ID+DB_ROLL_PTR+其他字段
這樣格式其中DB_TRX_ID+DB_ROLL_PTR作為一致性讀的關(guān)鍵信息存儲(chǔ)下來(lái),其中DB_TRX_ID在存儲(chǔ)上占用6字節(jié),DB_ROLL_PTR在存儲(chǔ)上占用7字節(jié)。那么DB_ROLL_PTR是如何解析到undo上的呢,這也是一位朋友問(wèn)的問(wèn)題。
下面是trx0types.h中對(duì)這部分的定義
/** Row identifier (DB_ROW_ID, DATA_ROW_ID) */typedef ib_id_t row_id_t;/** Transaction identifier (DB_TRX_ID, DATA_TRX_ID) */typedef ib_id_t trx_id_t;/** Rollback pointer (DB_ROLL_PTR, DATA_ROLL_PTR) */ typedef ib_id_t roll_ptr_t;
而ib_id_t實(shí)際上都是64位非負(fù)整數(shù)
typedef unsigned __int64 ib_uint64_t;
我大概看了一下流程如下:
trx_undo_prev_version_build //Build a previous version of a clustered index record ->roll_ptr = row_get_rec_roll_ptr(rec, index, offsets); //獲取rollback 指針 ->rec_trx_id = row_get_rec_trx_id(rec, index, offsets); //獲取TRX_ID ->trx_undo_get_undo_rec(roll_ptr, rec_trx_id, heap, is_redo_rseg,index->table->name, &undo_rec))//此處獲取前版本,獲取后放到undo_rec中 ->trx_undo_get_undo_rec_low(roll_ptr, heap, is_redo_rseg); //undo_rec作為傳出參數(shù)。傳出訪問(wèn)到的undo ->trx_undo_decode_roll_ptr //做roll_ptr的解析工作獲取segment id\page no\offset ->開(kāi)MTR獲取latch準(zhǔn)備拷貝 ->拷貝trx_undo_rec_copy ->提交MTR
實(shí)際上解析工具由trx_undo_decode_roll_ptr 完成。
其實(shí)解析挺簡(jiǎn)單,都是寫死了的。
/***********************************************************************//**
Decodes a roll pointer. */ //從高位到低位依次是 第1位是否是insert //第2到8位是segmentid//第9到40位為page no //第41位到56位為OFFSETUNIV_INLINEvoidtrx_undo_decode_roll_ptr(/*=====================*/
roll_ptr_t roll_ptr, /*!< in: roll pointer */
ibool* is_insert, /*!< out: TRUE if insert undo log */
ulint* rseg_id, /*!< out: rollback segment id */
ulint* page_no, /*!< out: page number */
ulint* offset) /*!< out: offset of the undo
entry within page */{#if DATA_ROLL_PTR_LEN != 7# error "DATA_ROLL_PTR_LEN != 7"#endif#if TRUE != 1# error "TRUE != 1"#endif
ut_ad(roll_ptr < (1ULL << 56));
*offset = (ulint) roll_ptr & 0xFFFF; //獲取低16位 為OFFSET
roll_ptr >>= 16; //右移16位
*page_no = (ulint) roll_ptr & 0xFFFFFFFF;//獲取32位為 page no
roll_ptr >>= 32;//右移32位
*rseg_id = (ulint) roll_ptr & 0x7F;//獲取7位為segment id
roll_ptr >>= 7;//右移7位
*is_insert = (ibool) roll_ptr; /* TRUE==1 *///最后一位}到此,相信大家對(duì)“怎么理解MySQL中Innodb DB_ROLL_PTR指針”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
當(dāng)前文章:怎么理解MySQL中InnodbDB_ROLL_PTR指針
網(wǎng)頁(yè)網(wǎng)址:http://www.chinadenli.net/article38/pgcepp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)網(wǎng)站制作、網(wǎng)頁(yè)設(shè)計(jì)公司、外貿(mào)網(wǎng)站建設(shè)、手機(jī)網(wǎng)站建設(shè)、全網(wǎng)營(yíng)銷推廣、軟件開(kāi)發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
網(wǎng)頁(yè)設(shè)計(jì)公司知識(shí)