成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

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

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

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

前言

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

整體結構

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

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

MySQL Protocol結構

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

query packet

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

result set packet

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

row packet

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

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

SQL Parse

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

對where的處理

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

當access層通過游標提供一系列row后,就可以通過這個樹狀表達式來過濾出符合where要求的數(shù)據(jù)。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],如下圖所示(假設兩張表數(shù)據(jù)一樣,便于繪圖):

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

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

B+Tree的磁盤結構

leaf磁盤結構

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

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

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

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

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

B+Tree在文件中的組織

有了Page結構,我們就可以將數(shù)據(jù)承載在一個個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+樹結構,沒有給其添加并發(fā)修改的鎖機制,也沒有在B+樹做操作的時候記錄log來保證B+樹在宕機等災難性情況下的一致性,所以就算完成了這么多的工作量,距離一個高并發(fā)高可用的bptree還有非常大的距離。

Meta Data

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

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

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

事務支持

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

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

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

WAL協(xié)議

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

回滾的實現(xiàn)

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

宕機恢復

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

Freedom運行

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

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

run alchemystar.freedom.engine.server.main

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

join查詢

delete回滾

尾聲

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

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

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

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

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

巨人網(wǎng)絡通訊聲明:本文標題《如何自己動手寫SQL執(zhí)行引擎》,本文關鍵詞  如何,自己,動,手寫,SQL,執(zhí)行,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《如何自己動手寫SQL執(zhí)行引擎》相關的同類信息!
  • 本頁收集關于如何自己動手寫SQL執(zhí)行引擎的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    国产日韩精品视频| 成人亚洲国产| 欧美日韩亚洲成人| 久久综合久久综合久久| 韩国精品在线观看| 99re在线播放| 久久久国产精品一区二区三区| 国产精品白丝av嫩草影院| youjizz.com亚洲| 日本三级久久| 日韩av午夜| 久久久久久12| 欧美色欧美亚洲另类七区| 好吊视频一二三区| 久久99精品久久久久久野外| 欧美日韩福利在线观看| 狠狠躁18三区二区一区| 欧美亚洲激情| 九九热精品视频国产| 欧美日韩在线国产| 久久久精品亚洲| 欧美日韩亚洲在线观看| 久久亚洲午夜电影| 7777久久香蕉成人影院| 韩国一区二区av| 国产曰批免费观看久久久| 国产日产亚洲系列最新| 亚洲国产精品久久久男人的天堂| 欧美日韩精品在线播放| 稀缺呦国内精品呦| 欧美一卡2卡3卡4卡无卡免费观看水多多| 8x8x国产| 久久久久久蜜桃一区二区| 亚洲午夜久久久久久久久红桃| 午夜成人免费影院| 久久久久久九九| 日韩精品a在线观看91| 三级视频在线看| 十大免费污污软件| 波多野结衣视频观看| 91国内精品久久| 天天爽天天爽天天爽| 国产一区二区精品| a级毛片免费| 亚洲色图制服丝袜| 久久亚洲精品中文字幕冲田杏梨| 久久xxxx精品视频| sis001亚洲原创区| 高清毛片在线看| 国产一级片免费看| www.超碰97| 最新欧美人z0oozo0| 日韩人妻无码精品综合区| 国产免费一区二区三区视频| 亚洲精品国产精品乱码不卡| 日韩精品视频中文在线观看| 日本中文字幕久久| 一区二区美女| 自拍偷拍亚洲精品| 最新中文字幕av| 成人国产在线看| 亚洲性69xxxbbb| 女教师高潮黄又色视频| 女厕盗摄一区二区三区| 欧美xxxx性xxxxx高清视频| 久色国产在线| 26uuu久久噜噜噜噜| 91一区二区视频| 成人小视频免费在线观看| 干b视频在线观看| 人人妻人人澡人人爽人人精品| 欧美大肚乱孕交hd孕妇| 亚洲午夜久久久| 在线观看av免费观看| 91免费看国产| 91在线观看免费高清完整版在线观看| 日韩av中文字幕一区| 欧美成人午夜做爰视频在线观看| 成人黄色激情网站| 成年人视频网站| 国产丝袜视频一区| 中文字幕欧美色图| 国产三级黄色片| 婷婷久久国产对白刺激五月99| 成人高清视频在线观看| 99国产在线播放| 精品国产一区久久久| 国产视频精品va久久久久久| 在线综合视频网站| 亚洲国产精彩中文乱码av在线播放| 国内视频一区| 福利在线一区二区三区| 九九爱精品视频| 99久久99九九99九九九| eeuss影院在线播放| 亚洲国产成人av好男人在线观看| 日韩精品在线私人| 亚洲一区国产| 青娱乐免费在线视频| 久久人人妻人人人人妻性色av| 成人在线播放网址| 九色porny丨国产精品| 欧美一级播放| 在线亚洲激情| 888奇米影视| 色av一区二区三区| 国产精品久久久久久久app| 裸体丰满少妇做受久久99精品| 久久免费美女视频| 欧美一二三四在线| 精品日产一区2区三区黄免费| 夜夜嗨一区二区三区| 国产91精品在线观看| 欧美精品乱码久久久久久按摩| 日韩精品欧美大片| 密臀av在线播放| 黄色a级片在线观看| 国产一二三区在线视频| av免费在线播放网站| 九色蝌蚪自拍| 亚洲成人一级片| 国产精品无码专区| 女人高潮被爽到呻吟在线观看| 国产精品无码网站| 日韩欧美另类在线| 99久久99久久免费精品蜜臀| 欧美在线关看| 黄色免费网站观看| 菠萝蜜网站在线观看| 亚洲精品电影在线一区| 亚洲天堂一区二区在线观看| 少妇特黄一区二区三区| 日韩在线第二页| 国产精品嫩草影院久久久| 麻豆91在线播放| 国产aⅴ综合色| 99久久久精品| 日韩欧美国产综合一区| 日韩免费高清av| 91免费看片在线| 国产 porn| 日本韩国欧美一区| 中文欧美在线视频| 国产调教一区二区三区| 久久免费精品视频| 国产精品久久久久影院色老大| 欧美在线不卡视频| 图片婷婷一区| 欧美精品久久99久久在免费线| 国产又大又黄又粗的视频| 欧美人与牲动交xxxx| 极品美女一区二区三区| 在线观看wwww| 性欧美18—19sex性高清| 亚洲成人五区| 激情综合色播激情啊| 日韩不卡一区| 人妻无码视频一区二区三区| 第四色亚洲色图| 四虎成人精品一区二区免费网站| 欧美视频在线观看一区二区| 成人污网站在线观看| 91国偷自产一区二区三区的观看方式| 免费日韩中文字幕| 欧美亚洲精品在线观看| 粉嫩av一区二区三区| 欧美日韩国产在线看| 超薄肉色丝袜一二三| 99久久精品无免国产免费| 一区二区三区四区在线播放| 欧美人与动性xxxxx杂性| 黑人玩欧美人三根一起进| juliaann成人作品在线看| 成人免费观看男女羞羞视频| 亚洲视频专区在线| 免费看啪啪网站| 在线观看日韩羞羞视频| 亚洲综合视频在线播放| 蜜桃视频在线入口www| 国产成人手机高清在线观看网站| 亚洲一区精品在线| 爱爱爱免费视频在线观看| 在线免费电影网| 亚洲熟妇国产熟妇肥婆| 996久久国产精品线观看| 国语精品中文字幕| 亚洲欧美日本伦理| 日韩av片在线看| 狠狠色噜噜狠狠色综合久| www.色在线| 欧美日韩免费观看一区二区三区| 日韩不卡av| 中国黄色a级片| 黄色av免费播放| 777琪琪电影午夜理伦片| 国产精品探花视频| 日本福利片高清在线观看| 柠檬在线导航福利| 黄视频网站免费看| 日韩成人一区| 亚洲欧美日韩国产成人综合一二三区| 日韩视频一区二区三区四区| 欧美福利在线观看| 国产精品一线天粉嫩av| 久久香蕉综合色一综合色88| 欧美乱妇一区二区三区不卡视频| 免费观看国产精品视频| 一区二区精品免费视频| 欧美不卡123| 无码国模国产在线观看| 福利在线免费视频| 国产精品久久久久久久天堂第1集| 亚洲精品国产系列| 成人高清在线观看免费| 丁香花五月激情| 伊人色综合影院| 亚洲自拍偷拍图| 国产毛片精品一区| 国产区二区三区| 91视视频在线直接观看在线看网页在线看| www亚洲色图| 91久久国产综合久久蜜月精品| 大伊香蕉精品在线品播放| 午夜精彩视频在线观看不卡| 久久九九热re6这里有精品| 先锋影音在av资源看片| 国产日韩欧美在线播放| 国产网红在线观看| 久精品免费视频| 最新av网站在线观看| 久久大逼视频| 成人高清视频在线| 亚洲色图偷窥| 五月天综合激情| 欧美在线不卡区| 国产激情精品一区二区三区| 日韩精品最新网址| 午夜视频免费播放| 毛片在线不卡| 色噜噜狠狠色综合欧洲selulu| 亚洲+变态+欧美+另类+精品| 国产一级黄色| 欧美高清视频在线播放| 两性午夜免费视频| 日本黄xxxxxxxxx100| 日本高清一区二区视频| 亚洲美女综合网| 男人日女人下面视频| 久久久综合av| 四虎影视网站| 国产精品三级一区二区| 欧洲成人免费视频| 亚洲人成影院在线观看| 精品国产一区二区三区成人影院| 久久精品国产一区二区三区不卡| 成人福利影院| 久草这里只有精品视频| 久久成人国产精品入口| 韩国女主播一区二区三区| xfplay精品久久| 欧美性猛交xxxx乱| 免费在线看v| 亚洲狼人综合网| 金瓶狂野欧美性猛交xxxx| 欧美成人免费视频a| 国产精品稀缺呦系列在线| 日韩三级在线观看| 中国色在线观看另类| 精品国产一区二区三区在线观看| 国产欧洲在线| 亚洲男人天堂色| 欧美怡红院视频一区二区三区| 欧美日一区二区在线观看| 免费男女羞羞的视频网站主页在线观看| 亚洲视频在线二区| 国产精品免费99久久久| 免费看a级黄色片| 亚洲国产欧洲综合997久久| 8888四色奇米在线观看| 欧美精品激情在线| 成人不用播放器| 色综合天天色| 一区二区三区四区久久| 九九视频直播综合网| 日产精品久久久久久久蜜臀| 午夜激情视频在线播放| 激情婷婷丁香| 一区二区在线高清视频| 最近中文字幕mv免费高清视频8| 日日夜夜精品视频天天综合网| 免费观看成年在线视频网站| 波多野结衣喷潮| 亚洲黄在线观看| 天堂√最新版中文在线| 国产成人综合网站| 一级片视频在线观看| 亚洲少妇久久久| 在线免费观看毛片| 国产a∨精品一区二区三区不卡| 成人久久视频在线观看| 大肉大捧一进一出好爽视频| 亚洲成人久久电影| 无码人妻丰满熟妇区毛片18| 色欧美88888久久久久久影院| 777久久精品一区二区三区无码| 美女隐私在线观看| 色免费在线视频| 亚洲精品国产综合久久| 国产精品资源在线看| 性欧美xxxx大乳国产app| 国产精品丝袜高跟| 欧美日韩一区二区视频在线观看| 五月天男人天堂| 日本不卡一二三区| 青娱乐在线免费视频| 亚洲黄色小说网站| 亚洲最大成人网站| 成熟老妇女视频| 日韩欧美aⅴ综合网站发布| 欧美亚洲午夜视频在线观看| 99免费看香蕉视频| 国产精品麻豆久久久| 疯狂欧美牲乱大交777| 激情中国色综合| 99久久精品一区二区三区| 小泽玛利亚一区| 北条麻妃99精品青青久久| 国产精品1luya在线播放|