BosCollege-SimpleDB-寫入一條數(shù)據(jù)

Author: Sixing Yan

1.前言

當數(shù)據(jù)庫系統(tǒng)執(zhí)行一條SQL語句的時候,它會為這條語句生成對應(yīng)的執(zhí)行計劃(Plan),針對查詢和更新兩種操作行為奕扣,計劃又分為查詢計劃和更新計劃。在SimpleDB中,plan 接口包含了一個Scan成員叔汁。客戶端接受SQL語句后民轴,會返回完成的這個SQL語句的計劃Plan攻柠。當客戶端開始讀取數(shù)據(jù)時,服務(wù)器就會根據(jù)這個Plan來執(zhí)行掃描數(shù)據(jù)Scan后裸。

在SimpleDB中瑰钮,所有的XXPlan 都實現(xiàn)了Plan接口(例如,ProjectPlan)微驶,而除了TableScan和SelectScan外浪谴,其他的XXScan都是實現(xiàn)Scan接口(例如开睡,ProjectScan)。因為TableScan和SelectScan這兩個會在update等操作里出現(xiàn)苟耻,所以用了特別的接口(UpdateScan)規(guī)范化它們的行為篇恒。

這一節(jié)通過解析“SimpleDB如何插入一條記錄”作為線索,來理清SimpleDB如何在數(shù)據(jù)表中插入一個數(shù)值凶杖。我們從TableScan開始胁艰,因為它繼承了UpdateScan接口,用于處理涉及Update(insert/update/delete)的情況(示意圖如下)智蝠。

How to set a value by SimpleDB

2.解析

TableScan>

tableScan 是實現(xiàn)了updateScan接口腾么,當往里面插入一個值時調(diào)用setVal方法,這個方法會先判斷對應(yīng)的fieldname是哪一種類型(通過Schema的type方法判斷)杈湾。這里假設(shè)該值是String類型的解虱,然后調(diào)用它的RecordFile成員rf的setString方法

TableScan>RecordFile

RecordFile rf 憑借TableInfo和Transaction 初始化,它將會通過RecordFormatter 生成一個符合Record標準的block漆撞,然后將這個block加入當前的文件(即是tableInfo所對應(yīng)的heap file)殴泰;接著把 blocknum游標(一個整型)移到0,然后用用該block number和當前文件名生成一個Block浮驳,并用該block悍汛,tableInfo 和 transaction 生成一個record管理器 RecordPage,即是對一個特定的Block的管理員抹恳。

回憶前面员凝,Block本身并沒有讀寫功能,而是Page對它有讀寫功能奋献,這樣對應(yīng)不同的結(jié)構(gòu)健霹,只要改變Page的讀寫方式即可。

于是乎瓶蚂,RecordFile有了RecordPage rp成員糖埋,當它執(zhí)行setString方法時,就調(diào)用Record Page rp 的setString窃这。

TableScan>RecordFile>RecordPage

Record Page 的setString 首先要獲得 一個位置參數(shù) position 來自 fieldpos(fldname)瞳别,具體是 當前的位置+這個列(field)的位移

當前位置通過 當前的slot編號 乘以 每個slot的size:currentslot * slotsize

這個位移來自需要調(diào)用TableInfo的offset方法確定該列的位移,原理是查找TableInfo ti 里的offset (Map<String, Integer>) 成員杭攻,查找該列的長度
然后調(diào)用Transaction tx的 setString祟敛。

回憶前面,RecordPage 的初始化使用了block兆解,tableInfo 和 transaction 三種參數(shù)
這里setString 即是使用這個指定的block馆铁,在指定的位置 position,插入確定類型的數(shù)值 val

TableScan>RecordFile>RecordPage>Transaction

調(diào)用Transaction 中的setString方法锅睛,這里將會在recoveryMgr和Buffer兩個地方插入數(shù)據(jù)埠巨。首先將傳入的block 上鎖(使用“一致性管理器” concurMgr.xLock方法)历谍。其次將這個block傳入buffer(myBufferrs.getBuffer),獲得一個Buffer對象 buff辣垒。接著先在“恢復(fù)管理器”recoveryMgr中保存這個數(shù)值 望侈,使用setFloat方法,傳入(buff, offset, val)勋桶,拿到一個與log有關(guān)的lsn參數(shù)脱衙。最后才執(zhí)行 Buffer對象的setString 方法(傳入offset, val, lsn, )

TableScan>RecordFile>RecordPage>Transaction>RecoveryMgr

于是recoveryMgr中的setString方法,首先拿出這個位置的舊的數(shù)值哥遮,然后向日志中插入這個舊的數(shù)據(jù)岂丘,然后返回插入日志的位置陵究。需要“恢復(fù)”的時候眠饮,就可以從這個日志的位置上讀回原來的數(shù)值了。

這里向日志插入舊數(shù)據(jù)的做法铜邮,是生成一個SetStringRecord對象的實例仪召,使用它的writeToLog方法

TableScan>RecordFile>RecordPage>Transaction>RecoveryMgr>SetStringRecord

初始化有兩種方法,一種是通過傳入指定參數(shù)松蒜,調(diào)用writeToLog來產(chǎn)生一條日志記錄扔茅。另一種方法通過讀取一條日志記錄,重現(xiàn)相關(guān)參數(shù)(傳入一個BasicLogRecord對象)

TableScan>RecordFile>RecordPage>Transaction>RecoveryMgr>SetStringRecord>LogRecord

這個接口包含“設(shè)定字符串型數(shù)據(jù)”的編號秸苗,SETSTRING=5.

TableScan>RecordFile>RecordPage>Transaction>RecoveryMgr>SetStringRecord>LogRecord>BasicLogRecord

這個對象包裝了對Page的讀寫

TableScan>RecordFile>RecordPage>Transaction>Buffer

buffer的setString 方法實際由page的setString執(zhí)行

TableScan>RecordFile>RecordPage>Transaction>Buffer>Page

在這個對象中召娜,最后由ByteBuffer 完成數(shù)據(jù)的插入,ByteBuffer 由java.nio.ByteBuffer 引入惊楼。

3.總結(jié)

可以看到玖瘸,當要寫入一個數(shù)值的時候,服務(wù)器會逐步委托到Record組件檀咙,根據(jù)record的規(guī)范來寫入給定數(shù)值雅倒;該數(shù)值會放入當前事務(wù)中進行處理;事務(wù)一方面委托文件系統(tǒng)來寫入數(shù)據(jù)到本地弧可,一方面則插入日志記錄以備將來undo使用蔑匣。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市棕诵,隨后出現(xiàn)的幾起案子裁良,更是在濱河造成了極大的恐慌,老刑警劉巖校套,帶你破解...
    沈念sama閱讀 217,657評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件价脾,死亡現(xiàn)場離奇詭異,居然都是意外死亡搔确,警方通過查閱死者的電腦和手機彼棍,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,889評論 3 394
  • 文/潘曉璐 我一進店門灭忠,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人座硕,你說我怎么就攤上這事弛作。” “怎么了华匾?”我有些...
    開封第一講書人閱讀 164,057評論 0 354
  • 文/不壞的土叔 我叫張陵映琳,是天一觀的道長。 經(jīng)常有香客問我蜘拉,道長萨西,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,509評論 1 293
  • 正文 為了忘掉前任旭旭,我火速辦了婚禮谎脯,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘持寄。我一直安慰自己源梭,他們只是感情好,可當我...
    茶點故事閱讀 67,562評論 6 392
  • 文/花漫 我一把揭開白布稍味。 她就那樣靜靜地躺著废麻,像睡著了一般。 火紅的嫁衣襯著肌膚如雪模庐。 梳的紋絲不亂的頭發(fā)上烛愧,一...
    開封第一講書人閱讀 51,443評論 1 302
  • 那天,我揣著相機與錄音掂碱,去河邊找鬼怜姿。 笑死,一個胖子當著我的面吹牛顶吮,可吹牛的內(nèi)容都是我干的社牲。 我是一名探鬼主播,決...
    沈念sama閱讀 40,251評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼悴了,長吁一口氣:“原來是場噩夢啊……” “哼搏恤!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起湃交,我...
    開封第一講書人閱讀 39,129評論 0 276
  • 序言:老撾萬榮一對情侶失蹤熟空,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后搞莺,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體息罗,經(jīng)...
    沈念sama閱讀 45,561評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,779評論 3 335
  • 正文 我和宋清朗相戀三年才沧,在試婚紗的時候發(fā)現(xiàn)自己被綠了迈喉。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片绍刮。...
    茶點故事閱讀 39,902評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖挨摸,靈堂內(nèi)的尸體忽然破棺而出孩革,到底是詐尸還是另有隱情,我是刑警寧澤得运,帶...
    沈念sama閱讀 35,621評論 5 345
  • 正文 年R本政府宣布膝蜈,位于F島的核電站,受9級特大地震影響熔掺,放射性物質(zhì)發(fā)生泄漏饱搏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,220評論 3 328
  • 文/蒙蒙 一置逻、第九天 我趴在偏房一處隱蔽的房頂上張望推沸。 院中可真熱鬧,春花似錦诽偷、人聲如沸坤学。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,838評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至压怠,卻和暖如春眠冈,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背菌瘫。 一陣腳步聲響...
    開封第一講書人閱讀 32,971評論 1 269
  • 我被黑心中介騙來泰國打工蜗顽, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人雨让。 一個月前我還...
    沈念sama閱讀 48,025評論 2 370
  • 正文 我出身青樓雇盖,卻偏偏與公主長得像,于是被迫代替她去往敵國和親栖忠。 傳聞我的和親對象是個殘疾皇子崔挖,可洞房花燭夜當晚...
    茶點故事閱讀 44,843評論 2 354

推薦閱讀更多精彩內(nèi)容

  • MySQL技術(shù)內(nèi)幕:InnoDB存儲引擎(第2版) 姜承堯 第1章 MySQL體系結(jié)構(gòu)和存儲引擎 >> 在上述例子...
    沉默劍士閱讀 7,417評論 0 16
  • Mysql概述 數(shù)據(jù)庫是一個易于訪問和修改的信息集合。它允許使用事務(wù)來確保數(shù)據(jù)的安全性和一致性庵寞,并能快速處理百萬條...
    彥幀閱讀 13,676評論 10 461
  • 我為什么不喜歡蕭紅? 我是不喜歡蕭紅的狸相,對于一個人,對于一個女人捐川,對于一個有才的女人脓鹃,對于一個有才的叛逆的女兒,對...
    豆子之不愛那么多閱讀 307評論 2 0
  • 那是我第一次離開中國古沥,是我第一次沒趕上飛機瘸右,是我第一次一個人跑了五個街區(qū)娇跟,是我第一次一個人逛完6層樓的美術(shù)館…無數(shù)...
    蔡不吃閱讀 253評論 0 0
  • 要點:1、Java動態(tài)性的兩種實現(xiàn)方法(反射和字節(jié)碼操作)2太颤、操作字節(jié)碼有什么作用3逞频、API的使用4、反編譯軟件X...
    灰色孤星閱讀 685評論 0 0