巧妙mybatis避免Where 空條件的尷尬
我就廢話不多說(shuō)了,大家還是直接看代碼吧~
<select id="findActiveBlogLike" resultType="Blog"> SELECT * FROM BLOG WHERE <if test="state != null"> state = #{state} </if> </select>
如果state參數(shù)為空時(shí),最終生成SQL語(yǔ)句為
SELECT * FROM BLOG
WHERE
執(zhí)行會(huì)出錯(cuò),當(dāng)然,你可以在where 后加一個(gè)1=1,改成
<select id="findActiveBlogLike" resultType="Blog"> SELECT * FROM BLOG WHERE 1=1 <if test="state != null"> and state = #{state} </if> </select>
但是這個(gè)做法不太“環(huán)保”(畢竟引入了一個(gè)垃圾條件),其實(shí)只要改成<where>...</where>即可
<select id="findActiveBlogLike" resultType="Blog"> SELECT * FROM BLOG <where> <if test="state != null"> and state = #{state} </if> </where> </select>
補(bǔ)充知識(shí):mybatis @Select注解中當(dāng)參數(shù)為空則不添加該參數(shù)的判斷
如下所示:
@Select("select * from "+DEPTTABLE+" ")
List<Dept> selectAllDept();
在mybatis中不用xml文件的形式,selectDept方法執(zhí)行的就是上面的Sql語(yǔ)句,如果是遇到動(dòng)態(tài)的語(yǔ)句就需要用到下面的形式。
1.用Provider去實(shí)現(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語(yǔ)法一樣書(shū)寫(xiě)
@Select({"<script>", "SELECT * FROM tbl_order", "WHERE 1=1", "<when test='title!=null'>", "AND mydate = #{mydate}", "</when>", "</script>"})
注意:方式1有個(gè)隱患就是當(dāng)傳入?yún)?shù)為空的時(shí)候,可能會(huì)造成全表查詢。
復(fù)雜SQL用方式2會(huì)比較靈活(當(dāng)然,并不建議寫(xiě)復(fù)雜SQL),而且可以抽象成通用的基類,使每個(gè)DAO都可以通過(guò)這個(gè)基類實(shí)現(xiàn)基本的通用查詢,原理類似Spring JDBC Template。
以上這篇巧妙mybatis避免Where 空條件的尷尬就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
MyBatis 源碼分析 之SqlSession接口和Executor類
mybatis框架在操作數(shù)據(jù)的時(shí)候,離不開(kāi)SqlSession接口實(shí)例類的作用,下面通過(guò)本文給大家實(shí)例剖析MyBatis 源碼分析之SqlSession接口和Executor類,需要的朋友參考下吧2017-02-02Jenkins節(jié)點(diǎn)配置實(shí)現(xiàn)原理及過(guò)程解析
這篇文章主要介紹了Jenkins節(jié)點(diǎn)配置實(shí)現(xiàn)原理及過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09使用socket進(jìn)行服務(wù)端與客戶端傳文件的方法
這篇文章主要介紹了使用socket進(jìn)行服務(wù)端與客戶端傳文件的方法,需要的朋友可以參考下2017-08-08SpringMVC HttpMessageConverter報(bào)文信息轉(zhuǎn)換器
??HttpMessageConverter???,報(bào)文信息轉(zhuǎn)換器,將請(qǐng)求報(bào)文轉(zhuǎn)換為Java對(duì)象,或?qū)ava對(duì)象轉(zhuǎn)換為響應(yīng)報(bào)文。???HttpMessageConverter???提供了兩個(gè)注解和兩個(gè)類型:??@RequestBody,@ResponseBody???,??RequestEntity,ResponseEntity??2023-01-01