Mybatis sql 如何進(jìn)行全自動(dòng)補(bǔ)全 檢測(cè)sql的正確性 提升開發(fā)效率

當(dāng)我們?cè)趯?mybatis的sql時(shí) 由于沒有sql自動(dòng)補(bǔ)全噪奄,寫sql花時(shí)間比較多 并且很容易寫錯(cuò)
只能通過(guò)寫testcase來(lái)看 sql是不是寫錯(cuò)了 一般項(xiàng)目中又用到了spring梗醇,大一點(diǎn)的項(xiàng)目啟動(dòng)spring就要花點(diǎn)時(shí)間,測(cè)試起來(lái)也比較麻煩

如果mybatis有sql的全自動(dòng)補(bǔ)全 并且能夠自己執(zhí)行sql就會(huì)方便很多

當(dāng)我們使用Intellij高級(jí)版時(shí)保屯,Intellij高級(jí)版有一個(gè)自帶的數(shù)據(jù)庫(kù), 在它的這個(gè)數(shù)據(jù)庫(kù)寫sql
時(shí)可以進(jìn)行全自動(dòng)的補(bǔ)全和檢測(cè)sql的正確性

并且Intellij 有一個(gè) Inject Language的功能竟终, 即我們可以把一種語(yǔ)言 注入到 一個(gè)字符串 或一個(gè) xml塊中

因此利用Intellij高級(jí)版 我們可以把 sql這種語(yǔ)言注入到我們寫的 mybatis的xml塊中

這樣mybatis的sql 就可以提供自動(dòng)補(bǔ)全了 (前提是我們要把數(shù)據(jù)庫(kù)給配置好)

截圖如下

  • Intellij高級(jí)版自帶的sql自動(dòng)補(bǔ)全和檢測(cè)


    Intellij自帶的sql的自動(dòng)補(bǔ)全.gif
  • 執(zhí)行sql


    Intellij自帶的數(shù)據(jù)庫(kù)執(zhí)行sql.gif

這樣的補(bǔ)全 其實(shí)就已經(jīng)方便很多了

但如果我們的sql里面添加了 include set trim where foreach這類mybatis自定義的標(biāo)簽的時(shí)候
在這些標(biāo)簽后面的sql不能進(jìn)行自動(dòng)補(bǔ)全 和識(shí)別了 由于Intellij不能識(shí)別這些標(biāo)簽 導(dǎo)致也不能執(zhí)行sql

以下是截圖

  • 無(wú)法識(shí)別mybatis的標(biāo)簽 點(diǎn)到標(biāo)簽后的列 無(wú)法補(bǔ)全和跳轉(zhuǎn)
    Intellij標(biāo)簽無(wú)法識(shí)別.gif

如何解決

  • 避免使用 where set trim 等標(biāo)簽 帶標(biāo)簽的sql 大部分是可以轉(zhuǎn)成不帶標(biāo)簽的

       SELECT <include refid="all_column"/>
        FROM comment_p_o
        <where>
            <if test="pojo.id != null"> AND id = #{pojo.id} </if>
            <if test="pojo.article_id != null"> AND article_id = #{pojo.article_id} </if>
        </where>

可以改寫為

      SELECT <include refid="all_column"/>
        FROM comment_p_o
        WHERE 1=1
            <if test="pojo.id != null"> AND id = #{pojo.id} </if>
            <if test="pojo.article_id != null"> AND article_id = #{pojo.article_id} </if>

對(duì)于 set 和 trim這種 如果有明確會(huì)更新的字段 也是可以轉(zhuǎn)的 把明確要改的字段 放在最后一個(gè) 就可以避免逗號(hào)的問題 但是對(duì)于下面這種 就沒辦法轉(zhuǎn)了

update order_info
    <set>
      <if test="orderId != null">
        order_id = #{orderId,jdbcType=VARCHAR},
      </if>
      <if test="userEmail != null">
        user_email = #{userEmail,jdbcType=VARCHAR},
      </if>
    </set>
    where id = #{id,jdbcType=INTEGER}

改寫為

update order_info
    set 
      <if test="orderId != null">
        order_id = #{orderId,jdbcType=VARCHAR},
      </if>
      <if test="userEmail != null">
        user_email = #{userEmail,jdbcType=VARCHAR}
      </if>
    where id = #{id,jdbcType=INTEGER}

就會(huì)有問題 如果 userEmail為空 sql就錯(cuò)了

所以這個(gè)方案不是很完美 所以有下面這個(gè)方案

由于Intellij 不支持 Mybatis的標(biāo)簽,要是Intellij能支持這塊就好了
幸運(yùn)的是柄粹,有一個(gè)Intellij 插件支持這個(gè)功能喘鸟,可以正確識(shí)別Mybatis的標(biāo)簽 在這些標(biāo)簽后面的sql可以自動(dòng)補(bǔ)全 可以識(shí)別帶標(biāo)簽的mybatis的語(yǔ)句 是否正確
從此不用擔(dān)心sql是否寫錯(cuò)
地址是: https://github.com/gejun123456/MyBatisCodeHelper-Pro

識(shí)別trim標(biāo)簽


識(shí)別trim標(biāo)簽.gif

識(shí)別set標(biāo)簽


識(shí)別set.gif

識(shí)別where標(biāo)簽


識(shí)別include和where.gif

sql是否正確檢測(cè)


檢測(cè)sql是否正確.gif

不過(guò)該插件是收費(fèi)的,一個(gè)月3元 一年29 歡迎各位免費(fèi)試用 http://brucege.com

當(dāng)然插件還有很多其他的功能 可以看插件的文檔 https://gejun123456.github.io/MyBatisCodeHelper-Pro/#/

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末驻右,一起剝皮案震驚了整個(gè)濱河市什黑,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌堪夭,老刑警劉巖愕把,帶你破解...
    沈念sama閱讀 217,406評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異森爽,居然都是意外死亡恨豁,警方通過(guò)查閱死者的電腦和手機(jī)橘蜜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門凡涩,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)力麸,“玉大人筋讨,你說(shuō)我怎么就攤上這事赤屋∶拿剑” “怎么了?”我有些...
    開封第一講書人閱讀 163,711評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵晴竞,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我已维,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,380評(píng)論 1 293
  • 正文 為了忘掉前任霉旗,我火速辦了婚禮读拆,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘屠列。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評(píng)論 6 392
  • 文/花漫 我一把揭開白布瘦材。 她就那樣靜靜地躺著,像睡著了一般眶拉。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,301評(píng)論 1 301
  • 那天劫樟,我揣著相機(jī)與錄音,去河邊找鬼。 笑死徐勃,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的劝堪。 我是一名探鬼主播搀玖,決...
    沈念sama閱讀 40,145評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼绣张,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了宋雏?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,008評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,443評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡难菌,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評(píng)論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了蚜迅。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片吵血。...
    茶點(diǎn)故事閱讀 39,795評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 35,501評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站篮赢,受9級(jí)特大地震影響涩澡,放射性物質(zhì)發(fā)生泄漏粥帚。R本人自食惡果不足惜赠群,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評(píng)論 3 328
  • 文/蒙蒙 一查描、第九天 我趴在偏房一處隱蔽的房頂上張望桥滨。 院中可真熱鬧,春花似錦、人聲如沸里初。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)拌汇。三九已至仇奶,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間掸掸,已是汗流浹背氯庆。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留扰付,地道東北人堤撵。 一個(gè)月前我還...
    沈念sama閱讀 47,899評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像羽莺,于是被迫代替她去往敵國(guó)和親实昨。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評(píng)論 2 354

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

  • 1. 簡(jiǎn)介 1.1 什么是 MyBatis 盐固? MyBatis 是支持定制化 SQL荒给、存儲(chǔ)過(guò)程以及高級(jí)映射的優(yōu)秀的...
    笨鳥慢飛閱讀 5,520評(píng)論 0 4
  • Mybatis相關(guān) 1.Mybatis是什么? 2.為什么選擇Mybatis? 3、#{}和${}的區(qū)別是什么刁卜? ...
    zhihaoZzz閱讀 1,282評(píng)論 0 2
  • 綿延依海岸志电, 九曲入林間。 寂寥獨(dú)行客蛔趴, 愁懷莫倚欄挑辆。
    塵寞閱讀 321評(píng)論 1 11
  • 中國(guó)的兵 作者的主要目的是要在零散材料的許可范圍內(nèi)看看由春秋時(shí)代到東漢末年當(dāng)兵的是什么人,兵的紀(jì)律怎么樣夺脾,兵的風(fēng)氣...
    古德曼Goodman閱讀 954評(píng)論 1 1
  • '''1之拨、勾股定理計(jì)算函數(shù),輸入3,4咧叭,輸出52蚀乔、將"When you are starting the sele...
    種樹在此時(shí)閱讀 369評(píng)論 0 0