怎么理解MySQL中InnodbDB_ROLL_PTR指針

本篇內容主要講解“怎么理解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指針”有了更深的了解,不妨來實際操作一番吧!這里是創新互聯網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

當前文章:怎么理解MySQL中InnodbDB_ROLL_PTR指針
網頁網址:http://www.kartarina.com/article38/pgcepp.html

成都網站建設公司_創新互聯,為您提供企業網站制作網頁設計公司外貿網站建設手機網站建設全網營銷推廣軟件開發

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都網站建設
主站蜘蛛池模板: 人妻少妇无码视频在线| 国产99久久九九精品无码| 国产自无码视频在线观看| 精品人妻无码区在线视频| 熟妇人妻中文字幕无码老熟妇| 无码中文字幕一区二区三区| 亚洲Av无码乱码在线播放| 亚洲av无码潮喷在线观看| 无码国产激情在线观看| 国产精品无码专区| 日韩精品无码久久一区二区三 | 亚洲AV永久无码精品一区二区国产| 五十路熟妇高熟无码视频 | 亚洲精品无码专区在线在线播放 | 亚洲中文字幕久久无码| 狠狠躁天天躁无码中文字幕 | 亚洲中文字幕无码爆乳av中文| 免费A级毛片无码视频| 亚洲精品无码av天堂| 免费无码成人AV片在线在线播放| 国产精品无码无需播放器| 亚洲中文字幕伊人久久无码| 亚洲色在线无码国产精品不卡| 亚洲AV区无码字幕中文色| 国产成人亚洲综合无码| 国产做无码视频在线观看| 亚洲av日韩aⅴ无码色老头| 精品亚洲成在人线AV无码| 久久亚洲精品无码AV红樱桃| 亚洲高清无码在线观看| 国产精品无码亚洲一区二区三区| 亚洲人片在线观看天堂无码 | 精品无码久久久久国产动漫3d| 国产V亚洲V天堂无码久久久| 潮喷无码正在播放| 亚洲无码视频在线| 国模无码一区二区三区不卡| 久久精品无码专区免费| 国产午夜无码片免费| 国产免费无码一区二区| 亚洲AV无码码潮喷在线观看|