巧妙mybatis避免Where 空条件的尴尬
我就廢話不多說了,大家還是直接看代碼吧~
<select id="findActiveBlogLike" resultType="Blog">SELECT * FROM BLOGWHERE<if test="state != null">state = #{state}</if> </select>如果state參數(shù)為空時,最終生成SQL語句為
SELECT * FROM BLOG
WHERE
執(zhí)行會出錯,當(dāng)然,你可以在where 后加一個1=1,改成
<select id="findActiveBlogLike" resultType="Blog">SELECT * FROM BLOGWHERE 1=1<if test="state != null">and state = #{state}</if> </select>但是這種做法有一個最大的弊端,就是導(dǎo)致數(shù)據(jù)表上的索引失效,如果有索引的話。而且還是一個垃圾條件
所以正確的做法應(yīng)該是:
使用<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注解中當(dāng)參數(shù)為空則不添加該參數(shù)的判斷
如下所示:
@Select("select * from “+DEPTTABLE+” ")
List selectAllDept();
在mybatis中不用xml文件的形式,selectDept方法執(zhí)行的就是上面的Sql語句,如果是遇到動態(tài)的語句就需要用到下面的形式。
1.用Provider去實現(xiàn)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有個隱患就是當(dāng)傳入?yún)?shù)為空的時候,可能會造成全表查詢。
復(fù)雜SQL用方式2會比較靈活(當(dāng)然,并不建議寫復(fù)雜SQL),而且可以抽象成通用的基類,使每個DAO都可以通過這個基類實現(xiàn)基本的通用查詢,原理類似Spring JDBC Template。
總結(jié)
以上是生活随笔為你收集整理的巧妙mybatis避免Where 空条件的尴尬的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Spring Boot配置MinIO(实
- 下一篇: pypthon3精要(11)-try,e