校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 如何自己動手寫SQL執(zhí)行引擎

如何自己動手寫SQL執(zhí)行引擎

熱門標(biāo)簽:高德地圖標(biāo)注商家在哪 hbuilder地圖標(biāo)注 400電話申請?jiān)趺纯?/a> 天音通信電話機(jī)器人 杭州400電話如何申請的 400電話從哪里申請濱州 隨州營銷電話機(jī)器人怎么樣 機(jī)器人電話機(jī)創(chuàng)意繪畫 江西南昌百應(yīng)電話機(jī)器人

前言

在閱讀了大量關(guān)于數(shù)據(jù)庫的資料后,筆者情不自禁產(chǎn)生了一個(gè)造數(shù)據(jù)庫輪子的想法。來驗(yàn)證一下自己對于數(shù)據(jù)庫底層原理的掌握是否牢靠。在筆者的github中給這個(gè)database起名為Freedom。

整體結(jié)構(gòu)

既然造輪子,那當(dāng)然得從前端的網(wǎng)絡(luò)協(xié)議交互到后端的文件存儲全部給擼一遍。下面是Freedom實(shí)現(xiàn)的整體結(jié)構(gòu),里面包含了實(shí)現(xiàn)的大致模塊:

最終存儲結(jié)構(gòu)當(dāng)然是使用經(jīng)典的B+樹結(jié)構(gòu)。當(dāng)然在B+樹和文件系統(tǒng)block塊之間的轉(zhuǎn)換則通過Buffer(Page) Manager來進(jìn)行。當(dāng)然了,為了完成事務(wù),還必須要用WAL協(xié)議,其通過Log Manager來操作。
Freedom采用的是索引組織表,通過DruidSQL Parse來將sql翻譯為對應(yīng)的索引操作符進(jìn)而進(jìn)行對應(yīng)的語義操作。

MySQL Protocol結(jié)構(gòu)

client/server之間的交互采用的是MySQL協(xié)議,這樣很容易就可以和mysql client以及jdbc進(jìn)行交互了。

query packet

mysql通過3byte的定長包頭去進(jìn)行分包,進(jìn)而解決tcp流的讀取問題。再通過一個(gè)sequenceId來再應(yīng)用層判斷packet是否連續(xù)。

result set packet

mysql協(xié)議部分最復(fù)雜的內(nèi)容是其對于result set的讀取,在NIO的方式下加重了復(fù)雜性。
Freedom通過設(shè)置一系列的讀取狀態(tài)可以比較好的在Netty框架下解決這一問題。

row packet

還有一個(gè)較簡單的是對row格式進(jìn)行讀取,如上圖所示,只需要按部就班的解析即可。

由于協(xié)議解析部分較為簡單,在這里就不再贅述。

SQL Parse

Freedom采用成熟好用的Druid SQL Parse作為解析器。事實(shí)上,解析sql就是將用文本表示
的sql語義表示為一系列操作符(這里限于篇幅原因,僅僅給出select中where過濾的原理)。

對where的處理

例如where后面的謂詞就可以表示為一系列的以樹狀結(jié)構(gòu)組織的SQL表達(dá)式,如下圖所示:

當(dāng)access層通過游標(biāo)提供一系列row后,就可以通過這個(gè)樹狀表達(dá)式來過濾出符合where要求的數(shù)據(jù)。Druid采用了Parse中常用的visitor很方便的處理上面的表達(dá)式計(jì)算操作。

對join的處理

對join最簡單處理方案就是對兩張表進(jìn)行笛卡爾積,然后通過上面的where condition進(jìn)行過濾,如下圖所示:

Freedom對于縮小笛卡爾積的處理

由于Freedom采用的是B+樹作為底層存儲結(jié)構(gòu),所以可以通過where謂詞來界定B+樹scan(搜索)的范圍(也即最大搜索key和最小搜索key在B+樹種中的位置)??紤]sql

select a.*,b.* from t_archer as a join t_rider as b where a.id>=3 and a.id=11 and b.id>=19 and b.id=31

那么就可以界定出在id這個(gè)索引上,a的scan范圍為[3,11],如下圖所示:

b的scan范圍為[19,31],如下圖所示(假設(shè)兩張表數(shù)據(jù)一樣,便于繪圖):

scan少了從原來的15*15(一共15個(gè)元素)次循環(huán)減少到4*4次循環(huán),即循環(huán)次數(shù)減少到7.1%

當(dāng)然如果存在join condition的話,那么Freedom在底層cursor遞歸處理的過程中會預(yù)先過濾掉一部分?jǐn)?shù)據(jù),進(jìn)一步減少上層的過濾。

B+Tree的磁盤結(jié)構(gòu)

leaf磁盤結(jié)構(gòu)

Freedom的B+Tree是存儲到磁盤里的。考慮到存儲的限制以及不定長的key值,所以會變得非常復(fù)雜。Freedom以page為單位來和磁盤進(jìn)行交互。葉子節(jié)點(diǎn)和非葉子節(jié)點(diǎn)都由page承載并刷入磁盤。結(jié)構(gòu)如下所示:

一個(gè)元組(tuple/item)在一個(gè)page中分為定長的ItemPointer和不定長的Item兩部分。
其中ItemPointer里面存儲了對應(yīng)item的起始偏移和長度。同時(shí)ItemPointer和Item如圖所示是向著中心方向進(jìn)行伸張,這種結(jié)構(gòu)很有效的組織了非定長Item。

leaf和node節(jié)點(diǎn)在Page中的不同

雖然leaf和node在page中組織結(jié)構(gòu)一致,但其item包含的項(xiàng)確有區(qū)別。由于Freedom采用的是索引組織表,所以對于leaf在聚簇索引(clusterIndex)和二級索引(secondaryIndex)中對item的表示也有區(qū)別,如下圖所示:

其中在二級索引搜索時(shí)通過secondaryIndex通過index-key找到對應(yīng)的clusterId,再通過
clusterId在clusterIndex中找到對應(yīng)的row記錄。
由于要落盤,所以Freedom在node節(jié)點(diǎn)中的item里面寫入了index-key對應(yīng)的pageno,
這樣就可以容易的從磁盤恢復(fù)所有的索引結(jié)構(gòu)了。

B+Tree在文件中的組織

有了Page結(jié)構(gòu),我們就可以將數(shù)據(jù)承載在一個(gè)個(gè)page大小的內(nèi)存里面,同時(shí)還可以將page刷新到對應(yīng)的文件里。有了node.item中的pageno,我們就可以較容易的進(jìn)行文件和內(nèi)存結(jié)構(gòu)之間的互相映射了。
B+樹在磁盤文件中的組織如下圖所示:

B+樹在內(nèi)存中相對應(yīng)的映射結(jié)構(gòu)如下圖所示:

文件page和內(nèi)存page中的內(nèi)容基本是一致的,除了一些內(nèi)存page中特有的字段,例如dirty等。

每個(gè)索引一個(gè)B+樹

在Freedom中,每個(gè)索引都是一顆B+樹,對記錄的插入和修改都要對所有的B+樹進(jìn)行操作。

B+Tree的測試

筆者通過一系列測試case,例如隨機(jī)變長記錄對B+樹進(jìn)行插入并落盤,修復(fù)了其中若干個(gè)非常詭異的corner case。

B+Tree的todo

筆者這里只是完成了最簡單的B+樹結(jié)構(gòu),沒有給其添加并發(fā)修改的鎖機(jī)制,也沒有在B+樹做操作的時(shí)候記錄log來保證B+樹在宕機(jī)等災(zāi)難性情況下的一致性,所以就算完成了這么多的工作量,距離一個(gè)高并發(fā)高可用的bptree還有非常大的距離。

Meta Data

table的元信息由create table所創(chuàng)建。創(chuàng)建之后會將元信息落盤,以便Freedom在重啟的時(shí)候加載表信息。每張表的元信息只占用一頁的空間,依舊復(fù)用page結(jié)構(gòu),主要保存的是聚簇索引和二級索引的信息。元信息對應(yīng)的Item如下圖所示:

如果想讓mybatis可以自動生成關(guān)于Freedom的代碼,還需實(shí)現(xiàn)一些特定的sql來展現(xiàn)Freedom的元信息。這個(gè)在筆者另一個(gè)項(xiàng)目rider中有這樣的實(shí)現(xiàn)。原理如下圖所示:

實(shí)現(xiàn)了上述4類SQL之后,mybatis-generator就可以通過jdbc從Freedom獲取元信息進(jìn)而自動生成代碼了。

事務(wù)支持

由于當(dāng)前Freedom并沒有保證并發(fā),所以對于事務(wù)的支持只做了最簡單的WAL協(xié)議。通過記錄redo/undolog從而實(shí)現(xiàn)原子性。

redo/undo log協(xié)議格式

Freedom在每做一個(gè)修改操作時(shí),都會生成一條日志,其中記錄了修改前(undo)和修改后(redo)的行信息,undo用來回滾,redo用來宕機(jī)recover。結(jié)構(gòu)如下圖所示:

WAL協(xié)議

WAL協(xié)議很好理解,就是在事務(wù)commit前將當(dāng)前事務(wù)中所產(chǎn)生的的所有l(wèi)og記錄刷入磁盤。
Freedom自然也做了這個(gè)操作,使得可以在宕機(jī)后通過log恢復(fù)出所有的數(shù)據(jù)。

回滾的實(shí)現(xiàn)

由于日志中記錄了undo,所以對于一個(gè)事務(wù)的回滾直接通過日志進(jìn)行undo即可。如下圖所示:

宕機(jī)恢復(fù)

Freedom如果在page全部刷盤之后關(guān)機(jī),則可以由通過加載page的方式獲取原來的數(shù)據(jù)。
但如果突然宕機(jī),例如kill -9之后,則可以通過WAL協(xié)議中記錄的redo/undo log來重新
恢復(fù)所有的數(shù)據(jù)。由于時(shí)間和精力所限,筆者并沒有實(shí)現(xiàn)基于LSN的檢查點(diǎn)機(jī)制。

Freedom運(yùn)行

git clone https://github.com/alchemystar/Freedom.git

// 并沒有做打包部署的工作,所以最簡單的方法是在java編輯器里面

run alchemystar.freedom.engine.server.main

以下是筆者實(shí)際運(yùn)行Freedom的例子:

join查詢

delete回滾

尾聲

在造輪子的過程中一開始是非常有激情非常快樂的。但隨著系統(tǒng)越來越龐大,復(fù)雜性越來越高,進(jìn)度就會越來越慢,還時(shí)不時(shí)要推翻自己原來的設(shè)想并重新設(shè)計(jì),然后再協(xié)同修改關(guān)聯(lián)的所有代碼,就如同泥沼,越陷越深。至此,筆者才領(lǐng)悟了軟件工程最重要的其實(shí)是控制復(fù)雜度!始終保持簡潔的接口和優(yōu)雅的設(shè)計(jì)是實(shí)現(xiàn)一個(gè)大型系統(tǒng)的必要條件。

github鏈接:https://github.com/alchemystar/Freedom

以上就是如何自己動手寫SQL執(zhí)行引擎的詳細(xì)內(nèi)容,更多關(guān)于自己動手寫SQL執(zhí)行引擎的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • SQL Server中的執(zhí)行引擎入門 圖解
  • MySQL 常見存儲引擎的優(yōu)劣
  • 修改MySQL數(shù)據(jù)庫引擎為InnoDB的操作
  • 關(guān)于MySQL Memory存儲引擎的相關(guān)知識
  • 詳解mysql中的存儲引擎
  • MySQL 選擇合適的存儲引擎
  • 聊聊MySQL中的存儲引擎
  • MySQL創(chuàng)建數(shù)據(jù)表時(shí)設(shè)定引擎MyISAM/InnoDB操作
  • 簡述MySQL InnoDB存儲引擎

標(biāo)簽:葫蘆島 沈陽 石嘴山 昆明 招商 保定 鶴崗 常德

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《如何自己動手寫SQL執(zhí)行引擎》,本文關(guān)鍵詞  如何,自己,動,手寫,SQL,執(zhí)行,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《如何自己動手寫SQL執(zhí)行引擎》相關(guān)的同類信息!
  • 本頁收集關(guān)于如何自己動手寫SQL執(zhí)行引擎的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    午夜精品福利一区二区三区av| 一区二区三区小说| 欧美高清在线一区二区| 亚洲男人的天堂在线aⅴ视频| 午夜精品爽啪视频| 91丝袜美女网| 精品国产乱码久久久久久浪潮| 亚洲精品国久久99热| 国产精品一级在线| 欧美浪妇xxxx高跟鞋交| 日韩一区在线播放| 国产激情一区二区三区桃花岛亚洲| 欧美日韩一区二区电影| 国产精品第13页| 国产精品系列在线观看| 欧美一区午夜精品| 亚洲.国产.中文慕字在线| av亚洲精华国产精华精华| 久久久天堂av| 美美哒免费高清在线观看视频一区二区| 日本韩国一区二区三区| 亚洲欧洲日韩av| 国产福利一区在线观看| 精品国产免费久久 | 亚洲男女一区二区三区| 处破女av一区二区| 久久久综合精品| 九色porny丨国产精品| 欧美理论片在线| 亚洲一区视频在线| 欧美性色欧美a在线播放| 1024成人网| 91免费版在线| 亚洲一区电影777| 欧美日韩一级黄| 亚洲18女电影在线观看| 欧美一区二区三区四区五区 | 国产老女人精品毛片久久| 欧美va亚洲va香蕉在线| 久久精工是国产品牌吗| 精品国产人成亚洲区| 国产最新精品免费| 久久女同精品一区二区| 国产黄人亚洲片| 国产精品国产三级国产aⅴ中文| www.欧美精品一二区| 国产精品国产自产拍高清av王其 | 亚洲精品国产a| 欧美午夜影院一区| 麻豆成人av在线| 久久蜜桃av一区二区天堂| 国产69精品一区二区亚洲孕妇 | 9久草视频在线视频精品| 最新不卡av在线| 欧美日韩一级黄| 久久精品国产在热久久| 国产精品伦理一区二区| 色综合久久久久综合99| 视频一区中文字幕| 久久久精品中文字幕麻豆发布| av日韩在线网站| 首页亚洲欧美制服丝腿| 国产欧美视频在线观看| 99久久精品情趣| 日本午夜一本久久久综合| 亚洲国产精品二十页| 欧美亚洲自拍偷拍| 国产经典欧美精品| 婷婷成人综合网| 日本一区二区视频在线观看| 欧洲一区在线观看| 国产在线视频精品一区| 亚洲一区自拍偷拍| 久久看人人爽人人| 欧美色涩在线第一页| 国产高清成人在线| 午夜精品久久一牛影视| 亚洲国产激情av| 欧美美女bb生活片| 97精品国产97久久久久久久久久久久| 午夜精品一区二区三区三上悠亚| 久久精品欧美一区二区三区麻豆 | 亚洲一区二区三区精品在线| 精品日本一线二线三线不卡| 在线看一区二区| 粉嫩13p一区二区三区| 美女视频黄 久久| 一区二区在线看| 国产欧美一区二区三区沐欲| 日韩一区二区三区三四区视频在线观看| eeuss鲁一区二区三区| 久久99九九99精品| 天天色综合成人网| 亚洲自拍偷拍av| 国产精品高潮久久久久无| 欧美va在线播放| 日韩一区二区三区免费看 | 日韩欧美一区二区不卡| 一本高清dvd不卡在线观看| 大白屁股一区二区视频| 国产剧情一区二区| 精品无码三级在线观看视频| 日本亚洲三级在线| 亚洲成人自拍网| 亚洲老妇xxxxxx| 综合久久一区二区三区| 国产视频一区在线观看| 欧美成人福利视频| 成人手机电影网| 欧美日韩一区久久| 色8久久人人97超碰香蕉987| 天堂一区二区在线免费观看| 日韩一区二区三区四区| av色综合久久天堂av综合| 99精品黄色片免费大全| 色婷婷精品大视频在线蜜桃视频 | 中文字幕一区日韩精品欧美| 国产精品成人一区二区艾草 | 欧美成人一区二区三区| 欧美一级欧美一级在线播放| 久久蜜臀精品av| 亚洲精选在线视频| 老司机免费视频一区二区三区| 国产成人精品影院| 在线视频一区二区三| 欧美成人在线直播| 亚洲欧美国产高清| 国产一区二区三区在线观看免费视频 | 男女性色大片免费观看一区二区| 精品在线一区二区| 欧美另类高清zo欧美| 亚洲一区二区三区四区五区中文| 久久成人免费日本黄色| 成人激情av网| 91成人在线免费观看| 国产女人18毛片水真多成人如厕 | 天堂蜜桃一区二区三区| 激情文学综合丁香| 欧美四级电影网| 国产精品乱子久久久久| 蜜臀av一区二区在线免费观看| av动漫一区二区| 久久精品视频在线免费观看| 天天做天天摸天天爽国产一区 | 开心九九激情九九欧美日韩精美视频电影| 成人性生交大合| 久久综合久久综合亚洲| 日本欧美一区二区在线观看| 欧美影院精品一区| 亚洲日本va在线观看| 国产成人亚洲综合a∨猫咪| 日韩欧美电影在线| 免费在线观看一区二区三区| 欧美视频你懂的| 一区2区3区在线看| 91在线观看成人| 亚洲日本欧美天堂| 成人aa视频在线观看| 国产亚洲成aⅴ人片在线观看 | 亚洲美女精品一区| 成人三级在线视频| 国产精品色一区二区三区| 国产精品一区二区视频| 久久久噜噜噜久久人人看 | 高清在线成人网| 国产日产精品1区| 国产精品一品视频| 久久青草欧美一区二区三区| 国产一区二区h| 国产欧美日韩三级| caoporn国产一区二区| 亚洲欧美综合色| 一本久道久久综合中文字幕| 亚洲欧美电影院| 欧美自拍丝袜亚洲| 亚洲aⅴ怡春院| 欧美精品成人一区二区三区四区| 三级在线观看一区二区| 91精品国产综合久久国产大片 | 激情综合色丁香一区二区| 精品乱码亚洲一区二区不卡| 国产在线日韩欧美| 国产精品高清亚洲| 色偷偷久久一区二区三区| 亚洲午夜免费视频| 日韩欧美123| 国产 欧美在线| 亚洲精品视频在线看| 欧美区在线观看| 捆绑调教美女网站视频一区| 久久久久亚洲蜜桃| 91香蕉国产在线观看软件| 亚洲主播在线观看| 欧美r级在线观看| av男人天堂一区| 日韩专区欧美专区| 久久精品一区四区| 日本久久电影网| 九色综合狠狠综合久久| 中文字幕一区二区三区四区不卡|