午夜视频免费看_日韩三级电影网站_国产精品久久一级_亚洲一级在线播放_人妻体内射精一区二区三区_91夜夜揉人人捏人人添红杏_91福利在线导航_国产又粗又猛又黄又爽无遮挡_欧美日韩一区在线播放_中文字幕一区二区三区四区不卡 _日日夜夜精品视频免费观看_欧美韩日一区二区三区

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

如何自己動手寫SQL執行引擎

熱門標簽:高德地圖標注商家在哪 hbuilder地圖標注 400電話申請怎么看 天音通信電話機器人 杭州400電話如何申請的 400電話從哪里申請濱州 隨州營銷電話機器人怎么樣 機器人電話機創意繪畫 江西南昌百應電話機器人

前言

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

整體結構

既然造輪子,那當然得從前端的網絡協議交互到后端的文件存儲全部給擼一遍。下面是Freedom實現的整體結構,里面包含了實現的大致模塊:

最終存儲結構當然是使用經典的B+樹結構。當然在B+樹和文件系統block塊之間的轉換則通過Buffer(Page) Manager來進行。當然了,為了完成事務,還必須要用WAL協議,其通過Log Manager來操作。
Freedom采用的是索引組織表,通過DruidSQL Parse來將sql翻譯為對應的索引操作符進而進行對應的語義操作。

MySQL Protocol結構

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

query packet

mysql通過3byte的定長包頭去進行分包,進而解決tcp流的讀取問題。再通過一個sequenceId來再應用層判斷packet是否連續。

result set packet

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

row packet

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

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

SQL Parse

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

對where的處理

例如where后面的謂詞就可以表示為一系列的以樹狀結構組織的SQL表達式,如下圖所示:

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

對join的處理

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

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

由于Freedom采用的是B+樹作為底層存儲結構,所以可以通過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這個索引上,a的scan范圍為[3,11],如下圖所示:

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

scan少了從原來的15*15(一共15個元素)次循環減少到4*4次循環,即循環次數減少到7.1%

當然如果存在join condition的話,那么Freedom在底層cursor遞歸處理的過程中會預先過濾掉一部分數據,進一步減少上層的過濾。

B+Tree的磁盤結構

leaf磁盤結構

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

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

leaf和node節點在Page中的不同

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

其中在二級索引搜索時通過secondaryIndex通過index-key找到對應的clusterId,再通過
clusterId在clusterIndex中找到對應的row記錄。
由于要落盤,所以Freedom在node節點中的item里面寫入了index-key對應的pageno,
這樣就可以容易的從磁盤恢復所有的索引結構了。

B+Tree在文件中的組織

有了Page結構,我們就可以將數據承載在一個個page大小的內存里面,同時還可以將page刷新到對應的文件里。有了node.item中的pageno,我們就可以較容易的進行文件和內存結構之間的互相映射了。
B+樹在磁盤文件中的組織如下圖所示:

B+樹在內存中相對應的映射結構如下圖所示:

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

每個索引一個B+樹

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

B+Tree的測試

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

B+Tree的todo

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

Meta Data

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

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

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

事務支持

由于當前Freedom并沒有保證并發,所以對于事務的支持只做了最簡單的WAL協議。通過記錄redo/undolog從而實現原子性。

redo/undo log協議格式

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

WAL協議

WAL協議很好理解,就是在事務commit前將當前事務中所產生的的所有log記錄刷入磁盤。
Freedom自然也做了這個操作,使得可以在宕機后通過log恢復出所有的數據。

回滾的實現

由于日志中記錄了undo,所以對于一個事務的回滾直接通過日志進行undo即可。如下圖所示:

宕機恢復

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

Freedom運行

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

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

run alchemystar.freedom.engine.server.main

以下是筆者實際運行Freedom的例子:

join查詢

delete回滾

尾聲

在造輪子的過程中一開始是非常有激情非常快樂的。但隨著系統越來越龐大,復雜性越來越高,進度就會越來越慢,還時不時要推翻自己原來的設想并重新設計,然后再協同修改關聯的所有代碼,就如同泥沼,越陷越深。至此,筆者才領悟了軟件工程最重要的其實是控制復雜度!始終保持簡潔的接口和優雅的設計是實現一個大型系統的必要條件。

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

以上就是如何自己動手寫SQL執行引擎的詳細內容,更多關于自己動手寫SQL執行引擎的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • SQL Server中的執行引擎入門 圖解
  • MySQL 常見存儲引擎的優劣
  • 修改MySQL數據庫引擎為InnoDB的操作
  • 關于MySQL Memory存儲引擎的相關知識
  • 詳解mysql中的存儲引擎
  • MySQL 選擇合適的存儲引擎
  • 聊聊MySQL中的存儲引擎
  • MySQL創建數據表時設定引擎MyISAM/InnoDB操作
  • 簡述MySQL InnoDB存儲引擎

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

巨人網絡通訊聲明:本文標題《如何自己動手寫SQL執行引擎》,本文關鍵詞  如何,自己,動,手寫,SQL,執行,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《如何自己動手寫SQL執行引擎》相關的同類信息!
  • 本頁收集關于如何自己動手寫SQL執行引擎的相關信息資訊供網民參考!
  • 推薦文章
    国产精品美女诱惑| 高清一区二区视频| 久久你懂得1024| 日日噜噜夜夜狠狠视频欧美人| 性猛交富婆╳xxx乱大交天津| 久久久蜜桃精品| 亚洲人成网站免费播放| 色综合中文字幕国产| 亚洲福利视频在线| 国产一区二区欧美日韩| 欧美日韩激情网| 国产精品美女久久福利网站| 国产精品电影一区二区三区| www.五月婷| 无套内谢大学处破女www小说| 白白色免费视频| 91插插插插插插| 波多野结衣久久久久| 青青草原免费观看| 不卡中文字幕在线| 免费看污污网站| 国产又黄又猛又爽| 亚洲男人天堂2021| 久热精品视频在线免费观看| 国产亚洲欧美激情| 91精东传媒理伦片在线观看| 国产麻豆午夜三级精品| 国产伦精品一区二区三区视频痴汉| 亚洲高清在线观看一区| 国产女主播av| 国产在线视频不卡| 91丝袜美腿美女视频网站| 91久久综合亚洲鲁鲁五月天| 91国产美女视频| 亚洲系列中文字幕| 欧美大片在线观看| 一本久久精品一区二区| 国产精品丝袜91| 探花国产精品一区二区| 无码人妻丰满熟妇精品| 蜜桃av乱码一区二区三区| 久久久久免费看黄a片app| 久久全国免费视频| 7777精品伊人久久久大香线蕉超级流畅| 成人毛片视频在线观看| 凸凹人妻人人澡人人添| 久热成人在线视频| 91热门视频在线观看| 欧美激情国产精品| 久久精品.com| 国产黄色av片| 欧美又粗又大又爽| 国产精品av免费| 美女爽到高潮91| 九九九在线视频| 污污的网站免费| 国产aaaaaaaaa| 丁香社区五月天| 日本少妇bbwbbw精品| 国产一级大片在线观看| 天天操天天干视频| 亚洲福利视频三区| 国产在线视频一区| www.欧美com| 一二三区中文字幕| 国产一区二区三区四区五区入口| 亚洲自拍欧美色图| 成人情趣片在线观看免费| 欧美va亚洲va在线观看蝴蝶网| 欧美国产一区二区| 蜜臀精品久久久久久蜜臀| 中文字幕一区二区三区在线不卡| 欧美福利电影网| 色欧美片视频在线观看在线视频| 日韩av在线免费观看| 成人亚洲激情网| 亚洲熟女毛茸茸| ...av二区三区久久精品| 国产精品观看在线亚洲人成网| 日韩久久久久久久久久久| 国产精品xxxx喷水欧美| 国产三级漂亮女教师| 国产精品影视网| 亚洲激情图片小说视频| 久久久成人精品| 777午夜精品福利在线观看| 日韩免费观看高清完整版| 欧美三级视频在线观看| 福利二区91精品bt7086| 日韩一区二区中文字幕| 国产精品日韩一区二区三区 | 国产综合色在线视频区| 欧美日韩免费在线| 久久国产精品免费观看| 日韩在线观看视频一区二区三区 | 久久免费美女视频| 欧美激情综合色| 欧美日韩亚洲在线| 噜噜噜久久亚洲精品国产品麻豆| 免费一级suv好看的国产网站| 国产精品国产精品国产专区| 成人午夜在线播放| 国内精品久久久久影院色| 日本中文字幕一区| 国产精品一区二区久久不卡 | 精品国产自在久精品国产| 色综合男人天堂| 欧美裸体网站| 91视频免费网址| 日韩精品视频免费| 给我看免费高清在线观看| 一区2区3区在线看| 国产一区国产精品| 国产成人综合欧美精品久久| 一区二区三区免费网站| 欧美久久久久久蜜桃| 99久热re在线精品996热视频| 中文字幕成人在线视频| 香蕉影院在线观看| 日产电影一区二区三区| 五月天婷婷在线播放| 亚洲色图日韩av| mm131国产精品| 欧美一级特黄aaaaaa大片在线观看| 亚洲欧美电影一区二区| 日韩亚洲在线观看| 欧美高清在线观看| 大尺度做爰床戏呻吟舒畅| 美日韩精品视频| 欧美人与性动交a欧美精品| 国产精品精品软件男同| 亚洲国产精品va在看黑人| 能直接看的av| 欧美成人精品福利| 欧美a v在线播放| 好男人在线视频www| 色综合天天综合网天天看片| 日本在线观看天堂男亚洲| 在线观看av免费观看| 国产精品亚洲午夜一区二区三区 | 亚洲欧美日韩电影| 日韩午夜电影av| 色一情一乱一伦一区二区三区 | 亚洲97在线观看| 国产精品无码电影| 亚洲嫩草精品久久| 久久久久久久久久久福利| 欧美日韩久久久久| 国产精品手机在线观看| 日韩精品在线观| 男人操女人动态图| 精品少妇一区二区三区免费观看| 在线日韩av永久免费观看| 久久国产乱子伦精品| 色狠狠桃花综合| 国产精品制服诱惑| 永久免费看片在线播放| 国产日韩欧美精品在线| 久久亚洲春色中文字幕| 免费观看精品视频| 久久一区二区三区国产精品| 在线观看欧美激情| 999久久久久久| 日韩精品在线视频观看| 日本激情综合网| 久草精品视频在线观看| 国产精品美女www爽爽爽| 国产伦理一区二区三区| 精品国产区一区二| 超碰在线观看97| 成人av资源网站| 国产一区二区在线视频播放| 一区二区三区美女| 亚洲精品永久视频| 亚洲色图制服丝袜| 国内精品国语自产拍在线观看| 天堂网中文在线观看| 欧美日韩成人综合天天影院| 亚洲图片欧洲图片日韩av| 国产毛片精品视频| 亚洲美女性视频| 自拍偷拍一区二区三区| 欧美一级淫片aaaaaa| 亚洲一区久久久| 久久精品91| 国产一区二区三区在线免费观看| 天天综合天天添夜夜添狠狠添| 亚洲小说欧美激情另类| 欧美成人高清电影在线| 激情 小说 亚洲 图片: 伦| 嫩草影院一区二区| 国产精品99久久99久久久二8| 国内精品免费午夜毛片| 国内久久久精品| 97香蕉超级碰碰久久免费软件| 欧美激情中文字幕在线| 91精品国产乱码久久久久久蜜臀| 668精品在线视频| 日韩av电影在线网| 国产精品一二区| 91沈先生作品| 国产一区二区三区奇米久涩| 久久综合九色欧美狠狠| 天天人人精品| 欧美人与动牲交xxxxbbbb| 国产真人做爰毛片视频直播| 成人精品视频一区二区| 国产精品久久久久久9999| 亚洲少妇一区二区| 久久精品—区二区三区舞蹈| 潮喷失禁大喷水aⅴ无码| 欧美成人免费观看视频| 欧美啪啪小视频| 国产精品一区二区三区在线免费观看| 精品人妻无码一区二区| 日韩中文字幕亚洲一区二区va在线| 蜜桃久久久久久| 成人av免费在线观看| 国产精品久久二区二区| 天天综合天天综合色| 精品视频1区2区3区| 日韩电影网在线| 丝袜美腿精品国产二区| 97精品伊人久久久大香线蕉| 国产精品美女主播在线观看纯欲| 成人黄色大片在线免费观看| 蜜桃视频在线观看成人| 成人午夜免费在线视频| 99sesese| www.av欧美| 日韩无码精品一区二区三区| 91精品国产乱码久久久久| 无码国产精品高潮久久99| 国产激情91久久精品导航| 欧美激情一区二区| 福利一区福利二区微拍刺激| 日韩欧美亚洲国产另类| 菠萝蜜影院一区二区免费| 日韩**中文字幕毛片| 国产在线精品一区| 欧美图片激情小说| 中文字幕 欧美 日韩| 老司机成人免费视频| 一区二区视频免费| 美女一区二区视频| 日本一区二区三区dvd视频在线| 亚洲国产日韩综合久久精品| 日韩写真欧美这视频| 欧美成人午夜激情视频| 亚洲精品欧美极品| 国产一二三四区在线观看| 五月天中文字幕在线| 91动漫免费网站| 一本色道久久综合熟妇| 狠狠网亚洲精品| 一区二区三区在线高清| 欧美一二区视频| 欧美精品一区二区免费| 97人人干人人| 成人性生活视频免费看| 大乳护士喂奶hd| 五月婷婷亚洲综合| 日韩和欧美一区二区三区| 国产色产综合色产在线视频| 欧美色手机在线观看| 中文字幕亚洲一区在线观看| 国产日韩欧美视频在线| 裸体裸乳免费看| 中文字幕在线观看91| 91国产丝袜播放在线| 日韩精品91亚洲二区在线观看| 国产喷白浆一区二区三区| 欧美日韩免费视频| 久久成人精品电影| 国产一区二区三区奇米久涩| 成人久久久久久久久| 多男操一女视频| 国产成人手机在线| 国产欧美日韩亚州综合| 欧美一级二级三级乱码| 欧美伊久线香蕉线新在线| 偷拍视频一区二区| 少妇极品熟妇人妻无码| 久草国产精品视频| 麻豆精品一区二区三区| 一个色综合av| 亚洲最新视频在线| 国产欧美一区二区三区另类精品| 久久久久久久久久久免费视频| 熟女av一区二区| 亚洲区小说区图片区| 亚洲狠狠丁香婷婷综合久久久| 日韩大陆欧美高清视频区| 国产精品主播视频| 无罩大乳的熟妇正在播放| 欧美日韩国产一二三区| 三级小视频在线观看| 综合久久久久久| 亚洲欧洲午夜一线一品| 97免费高清电视剧观看| 天堂av在线8| 蜜臀尤物一区二区三区直播| 91亚洲精品久久久蜜桃网站 | 女人色极品影院| 人妻精品久久久久中文| 老牛影视av牛牛影视av| 亚洲欧美日韩电影| 在线观看日韩www视频免费| 久久精品一二三区| 一级片黄色免费| 亚洲天堂一二三| 亚洲国产成人在线| 亚洲精品日韩在线| 韩国一区二区三区美女美女秀 | 91久久精品国产91性色69| 国产亚洲综合av| 亚洲乱码国产乱码精品精天堂| 91精品天堂| 九九九久久久久久久| 国产精品视频第一页| 亚洲人精品午夜| 欧美成人午夜免费视在线看片| 在线视频不卡一区二区三区| 91成人精品一区二区| 精品一区二区三区在线观看 | 国产精品入口免费视| 亚洲视频在线a| 影音先锋国产在线| 亚洲天堂网中文字| 欧美老女人性视频| 国产玉足脚交久久欧美| xxxx 国产| 久久综合色鬼综合色| 亚洲视频一区二区三区| 视频在线一区二区三区| av黄色免费在线观看| 国产盗摄女厕一区二区三区| 欧美不卡一区二区三区| 亚洲va欧美va在线观看| 男人女人拔萝卜视频| 日韩中文字幕综合| 在线观看欧美黄色| 成人有码视频在线播放| 制服丝袜在线第一页| 久久亚洲综合| 欧美日韩国产另类一区| 99蜜桃在线观看免费视频网站| 亚洲视频在线不卡| 欧美自拍第一页| 欧美日韩在线播| 成人看片视频| 国产jk精品白丝av在线观看| 国产一区二区成人久久免费影院| 亚洲国产精品久久| 亚洲第一在线综合在线| 青青草手机在线观看| 久久精品日韩一区二区三区| 久久九九国产精品怡红院 | 成人18视频| 亚洲精品一区二区三区影院忠贞| 国产精品亚洲专一区二区三区 | 中文在线观看免费网站| 国产精品视频看| 韩国日本不卡在线| 天天操天天干天天做| 午夜激情在线视频| 欧美一区日韩一区| 日本欧美精品久久久| 久久久久99精品| 国产精品久久久久久久久晋中| 韩剧1988在线观看免费完整版| 日本特黄a级片| 丝袜诱惑亚洲看片| 亚洲第一福利视频| 亚洲资源在线网| 日本黄色一级视频| 第一福利永久视频精品| 99re视频在线| 2025国产精品自拍| 国产精品网站在线播放| 国外成人在线视频| 少妇献身老头系列| 国产黄色成人av| 九九精品在线播放| 亚洲理论中文字幕| 国产精品一区2区| 久久综合伊人77777尤物| 少妇性l交大片| 凸凹人妻人人澡人人添| 亚洲国产精品久久| 91午夜在线观看| 超碰在线播放97| 91精品国产综合久久久蜜臀图片 | 糖心vlog免费在线观看| 国产精品狼人久久影院观看方式| 日本精品va在线观看| 国产精品免费无码| 中文字幕国产一区| 国产啪精品视频| 手机在线中文字幕| 亚洲美女免费视频| 999视频在线免费观看| 九九视频免费观看| 午夜亚洲福利老司机| 久久国产一区| 国产黄色免费视频| 欧美一区二区三区视频免费 | 亚洲影视在线观看| 国产精品一区二区三区不卡| 日本道在线观看|