巧妙mybatis避免Where 空条件的尴尬
生活随笔
收集整理的這篇文章主要介紹了
巧妙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 空条件的尴尬的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Spring Boot配置MinIO(实
- 下一篇: pypthon3精要(11)-try,e