日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

巧妙mybatis避免Where 空条件的尴尬

發布時間:2025/3/12 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 巧妙mybatis避免Where 空条件的尴尬 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

我就廢話不多說了,大家還是直接看代碼吧~

<select id="findActiveBlogLike" resultType="Blog">SELECT * FROM BLOGWHERE<if test="state != null">state = #{state}</if> </select>

如果state參數為空時,最終生成SQL語句為

SELECT * FROM BLOG

WHERE

執行會出錯,當然,你可以在where 后加一個1=1,改成

<select id="findActiveBlogLike" resultType="Blog">SELECT * FROM BLOGWHERE 1=1<if test="state != null">and state = #{state}</if> </select>

但是這種做法有一個最大的弊端,就是導致數據表上的索引失效,如果有索引的話。而且還是一個垃圾條件

所以正確的做法應該是:

使用<where>標簽 解決這個問題

where標簽會自動處理第一個為null時候的and問題

<select id="findActiveBlogLike" resultType="Blog">SELECT * FROM BLOG<where><if test="state != null">and state = #{state}</if></where> </select>

補充知識:mybatis @Select注解中當參數為空則不添加該參數的判斷

如下所示:

@Select("select * from “+DEPTTABLE+” ")

List selectAllDept();

在mybatis中不用xml文件的形式,selectDept方法執行的就是上面的Sql語句,如果是遇到動態的語句就需要用到下面的形式。

1.用Provider去實現SQL拼接:

@SelectProvider(type=DeptDynaSqlProvider.class,method="count")Integer count(Map<String, Object> params); //DeptDynaSqlProvider.class 類中的方法 public String count(Map<String, Object> params){ return new SQL(){{SELECT("count(*)");FROM(DEPTTABLE);if(params.get("dept") != null){Dept dept = (Dept) params.get("dept");if(dept.getName() != null && !dept.getName().equals("")){WHERE(" name LIKE CONCAT ('%',#{dept.name},'%') ");}}}}.toString();}

2.還有一種方式是用script標簽包圍,像xml語法一樣書寫

@Select({"<script>","SELECT * FROM tbl_order","WHERE 1=1","<when test='title!=null'>","AND mydate = #{mydate}","</when>","</script>"})

**注意:**方式1有個隱患就是當傳入參數為空的時候,可能會造成全表查詢。

復雜SQL用方式2會比較靈活(當然,并不建議寫復雜SQL),而且可以抽象成通用的基類,使每個DAO都可以通過這個基類實現基本的通用查詢,原理類似Spring JDBC Template。

總結

以上是生活随笔為你收集整理的巧妙mybatis避免Where 空条件的尴尬的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。