您好,登錄后才能下訂單哦!
本篇內容主要講解“怎么理解MySQL中Innodb DB_ROLL_PTR指針”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“怎么理解MySQL中Innodb DB_ROLL_PTR指針”吧!
我們知道每一條記錄在聚集索引上都有如下的分布:
rowid(主鍵)+DB_TRX_ID+DB_ROLL_PTR+其他字段
這樣格式其中DB_TRX_ID+DB_ROLL_PTR作為一致性讀的關鍵信息存儲下來,其中DB_TRX_ID在存儲上占用6字節,DB_ROLL_PTR在存儲上占用7字節。那么DB_ROLL_PTR是如何解析到undo上的呢,這也是一位朋友問的問題。
下面是trx0types.h中對這部分的定義
/** 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實際上都是64位非負整數
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作為傳出參數。傳出訪問到的undo ->trx_undo_decode_roll_ptr //做roll_ptr的解析工作獲取segment id\page no\offset ->開MTR獲取latch準備拷貝 ->拷貝trx_undo_rec_copy ->提交MTR
實際上解析工具由trx_undo_decode_roll_ptr 完成。
其實解析挺簡單,都是寫死了的。
/***********************************************************************//** 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 *///最后一位}
到此,相信大家對“怎么理解MySQL中Innodb DB_ROLL_PTR指針”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。