日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL:Innodb DB_ROLL_PTR指针解析

發布時間:2025/4/16 数据库 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL:Innodb DB_ROLL_PTR指针解析 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

源碼版本5.7.22

此處簡單記錄一下DB_ROLL_PTR指針解析的方法,水平有限,如果有誤請諒解。

一、引入

我們知道每一條記錄在聚集索引上都有如下的分布:

  • rowid(主鍵)+DB_TRX_ID+DB_ROLL_PTR+其他字段
    這樣格式其中DB_TRX_ID+DB_ROLL_PTR作為MVCC的關鍵信息存儲下來,其中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位為OFFSET UNIV_INLINE void trx_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 undoentry within page */ { #if DATA_ROLL_PTR_LEN != 7 # error "DATA_ROLL_PTR_LEN != 7" #endif #if TRUE != 1 # error "TRUE != 1" #endifut_ad(roll_ptr < (1ULL << 56));*offset = (ulint) roll_ptr & 0xFFFF; //獲取低16位 為OFFSETroll_ptr >>= 16; //右移16位*page_no = (ulint) roll_ptr & 0xFFFFFFFF;//獲取32位為 page noroll_ptr >>= 32;//右移32位*rseg_id = (ulint) roll_ptr & 0x7F;//獲取7位為segment idroll_ptr >>= 7;//右移7位*is_insert = (ibool) roll_ptr; /* TRUE==1 *///最后一位 }

參考注釋。自行理解。

作者微信號碼:gp_22389860

總結

以上是生活随笔為你收集整理的MySQL:Innodb DB_ROLL_PTR指针解析的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 韩国毛片一区二区三区 | 日本久久激情 | 亚洲欧美精品一区 | 日本激情视频网站 | 国产原创视频 | 久久久极品 | 久草中文在线 | 日韩福利在线观看 | 黄色片国产| 91精品国自产在线观看 | 国产伦精品一区二区 | 99热麻豆| 麻豆久久久9性大片 | 清冷男神被c的合不拢腿男男 | 亚洲国产成人精品久久久 | 三级在线网站 | 欧美性欧美zzzzzzzzz | 成年人免费看 | 午夜黄色一级片 | 四虎在线视频免费观看 | 美女三级黄色片 | 夜色导航| 国产精品刘玥久久一区 | 国产精品99久久久久久久久久久久 | 午夜寂寞福利 | 国产麻豆一精品一av一免费 | zzjj国产精品一区二区 | 亚洲精品中文字幕乱码三区 | 成人av免费在线播放 | 国产精品suv一区二区88 | 美女吞精视频 | 日日日人人人 | 无遮挡边吃摸边吃奶边做 | 久久在线一区二区 | 欧美性在线观看 | 91精品国产闺蜜国产在线闺蜜 | 制服一区二区 | 亚洲伦理网 | 色戒av | 激情五月婷婷色 | av在线第一页 | 在线日韩三级 | 亚洲综合涩 | 性欧美丰满熟妇xxxx性仙踪林 | 色av导航 | 伊人天天干 | 美乳人妻一区二区三区 | 亚洲干 | 日韩精品字幕 | 亚洲成人精品网 | 亚洲成熟少妇视频在线观看 | 亚洲美免无码中文字幕在线 | 午夜视频大全 | 少妇被躁爽到高潮无码人狍大战 | 制服丝袜先锋 | 国产激情视频网站 | 日韩a级在线观看 | 国产高清不卡 | 99色播| 日韩99| 午夜爱爱网站 | 永久中文字幕 | 台湾佬美性中文 | 亚洲AV无码成人精品国产一区 | 一级片播放 | 日本三级韩国三级三级a级中文 | 亚洲砖区区免费 | 91桃色网站| 手机看片国产精品 | 国产美女性生活 | 五月婷婷综 | 欧美性大战久久久久久久蜜桃 | 亚洲一级Av无码毛片久久精品 | 亚洲午夜久久久久久久久红桃 | 天天干夜夜撸 | 午夜精品视频一区 | 91sao| 中文字幕观看视频 | 国产一级二级 | 久久人人爽人人人人片 | 日本丰满熟妇videossex一 | 日韩高清不卡一区 | 精品国产久 | 国产精品老熟女视频一区二区 | 久久新视频 | 老色批影视 | 大奶子在线观看 | 四虎影库| 国产ts变态重口人妖hd | 国产亚洲一区二区三区不卡 | 香蕉视频久久久 | 国产精品久久久一区二区 | 久久国产精品久久国产精品 | 香蕉视频污在线观看 | www.色网站| 久久精品99久久久久久 | 日本激情网址 | 日本精品人妻无码免费大全 | 日韩激情啪啪 |