calcite 是一個(gè)數(shù)據(jù)源管理工具译断,前面已經(jīng)講到的,這里來(lái)講講基于calcite 實(shí)現(xiàn)方言的切換。比如最近比較火的信創(chuàng)鸠蚪,或許可以幫我們大忙。
假定我們的sql如下:
select * from table limit 1
而如果此時(shí)我需要在sqlserver 庫(kù)下執(zhí)行此sql师溅,那么必然是不能執(zhí)行的茅信,因?yàn)閟qlserver 是不支持limit語(yǔ)法的。而我們可以通過(guò)calcite指定源sql語(yǔ)法為mysql墓臭,此時(shí)蘸鲸,在對(duì)應(yīng)數(shù)據(jù)庫(kù)執(zhí)行時(shí)會(huì)自動(dòng)翻譯為sqlserver。
如果你使用了連接池窿锉,可以在獲取calcite 連接的時(shí)候指定:
此時(shí)酌摇,calcite將以mysql標(biāo)準(zhǔn)語(yǔ)法去解析你編寫(xiě)的sql。
前一文我們對(duì)calcite JdbcScheme進(jìn)行了源碼級(jí)解析(http://www.reibang.com/p/d62adef269b2?v=1732787956843)榆综。
我們知道妙痹,calcite 會(huì)先將mysql 語(yǔ)法轉(zhuǎn)換為關(guān)系代數(shù),再將關(guān)系代數(shù)轉(zhuǎn)換為sql對(duì)象鼻疮,再將sql對(duì)象根據(jù)不同的方言進(jìn)行sql輸出怯伊,可以達(dá)到方言轉(zhuǎn)換的目的。這樣就可以大大減輕數(shù)據(jù)庫(kù)信創(chuàng)的工作量(當(dāng)然很多信創(chuàng)數(shù)據(jù)庫(kù)沒(méi)有實(shí)現(xiàn)判沟,需要自己去實(shí)現(xiàn)對(duì)應(yīng)的方言耿芹,這里僅提供一些思路,本人也實(shí)現(xiàn)了一些信創(chuàng)挪哄,但這里不方便公開(kāi)出來(lái))吧秕。
按此操作后,你就會(huì)驚喜的發(fā)現(xiàn)迹炼,最終執(zhí)行的sql會(huì)被翻譯為:
select top(1) * from table
不過(guò)在mysql 分頁(yè)在轉(zhuǎn)sqlserver的時(shí)候砸彬,需要注意編寫(xiě)order by 語(yǔ)句颠毙,這塊社區(qū)已經(jīng)有issue了,原因可以參考:
https://issues.apache.org/jira/browse/CALCITE-4968