巧妙mybatis避免Where 空條件的尷尬
我就廢話不多說了,大家還是直接看代碼吧~
<select id="findActiveBlogLike" resultType="Blog"> SELECT * FROM BLOG WHERE <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 BLOG WHERE 1=1 <if test="state != null"> and state = #{state} </if> </select>
但是這個做法不太“環(huán)?!保ó吘挂肓艘粋€垃圾條件),其實只要改成<where>...</where>即可
<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<Dept> 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標(biāo)簽包圍,像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。
以上這篇巧妙mybatis避免Where 空條件的尷尬就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
MyBatis 源碼分析 之SqlSession接口和Executor類
mybatis框架在操作數(shù)據(jù)的時候,離不開SqlSession接口實例類的作用,下面通過本文給大家實例剖析MyBatis 源碼分析之SqlSession接口和Executor類,需要的朋友參考下吧2017-02-02Jenkins節(jié)點配置實現(xiàn)原理及過程解析
這篇文章主要介紹了Jenkins節(jié)點配置實現(xiàn)原理及過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-09-09使用socket進(jìn)行服務(wù)端與客戶端傳文件的方法
這篇文章主要介紹了使用socket進(jìn)行服務(wù)端與客戶端傳文件的方法,需要的朋友可以參考下2017-08-08SpringMVC HttpMessageConverter報文信息轉(zhuǎn)換器
??HttpMessageConverter???,報文信息轉(zhuǎn)換器,將請求報文轉(zhuǎn)換為Java對象,或?qū)ava對象轉(zhuǎn)換為響應(yīng)報文。???HttpMessageConverter???提供了兩個注解和兩個類型:??@RequestBody,@ResponseBody???,??RequestEntity,ResponseEntity??2023-01-01