欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

巧妙mybatis避免Where 空條件的尷尬

 更新時(shí)間:2020年11月27日 14:51:43   作者:susu11581147324  
這篇文章主要介紹了巧妙mybatis避免Where 空條件的尷尬,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

我就廢話不多說(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)文章

  • SparkSQL快速入門(mén)教程

    SparkSQL快速入門(mén)教程

    Spark?SQL是Spark用于結(jié)構(gòu)化數(shù)據(jù)(structured?data)處理的Spark模塊,今天通過(guò)本文給大家介紹SparkSQL快速入門(mén)教程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2022-02-02
  • springboot文件上傳保存路徑的問(wèn)題

    springboot文件上傳保存路徑的問(wèn)題

    這篇文章主要介紹了springboot文件上傳保存路徑的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • MyBatis 源碼分析 之SqlSession接口和Executor類

    MyBatis 源碼分析 之SqlSession接口和Executor類

    mybatis框架在操作數(shù)據(jù)的時(shí)候,離不開(kāi)SqlSession接口實(shí)例類的作用,下面通過(guò)本文給大家實(shí)例剖析MyBatis 源碼分析之SqlSession接口和Executor類,需要的朋友參考下吧
    2017-02-02
  • Jenkins節(jié)點(diǎn)配置實(shí)現(xiàn)原理及過(guò)程解析

    Jenkins節(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
  • Java多線程編程之Lock用法實(shí)例

    Java多線程編程之Lock用法實(shí)例

    這篇文章主要介紹了Java多線程編程之Lock用法實(shí)例,本文直接給出代碼實(shí)例,需要的朋友可以參考下
    2015-05-05
  • Java如何調(diào)用C++ DLL庫(kù)

    Java如何調(diào)用C++ DLL庫(kù)

    本文重點(diǎn)給大家介紹java中調(diào)用c++ dll庫(kù)的方法,本文分步驟介紹的非常詳細(xì),感興趣的朋友可以參考下
    2016-06-06
  • 使用socket進(jìn)行服務(wù)端與客戶端傳文件的方法

    使用socket進(jìn)行服務(wù)端與客戶端傳文件的方法

    這篇文章主要介紹了使用socket進(jìn)行服務(wù)端與客戶端傳文件的方法,需要的朋友可以參考下
    2017-08-08
  • SpringMVC HttpMessageConverter報(bào)文信息轉(zhuǎn)換器

    SpringMVC 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
  • java Object wait方法詳細(xì)介紹

    java Object wait方法詳細(xì)介紹

    這篇文章主要介紹了java Object wait方法詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下
    2017-02-02
  • Java 邏輯控制全面詳解

    Java 邏輯控制全面詳解

    程序的邏輯主要分為三種結(jié)構(gòu):順序結(jié)構(gòu)、分支結(jié)構(gòu)、循環(huán)結(jié)構(gòu),順序結(jié)構(gòu)的所有的代碼都是從前向后執(zhí)行的。有些時(shí)候順序是由“{}”為界限的,下文將全面詳細(xì)的介紹
    2021-10-10

最新評(píng)論