=, "/>

一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - mybatis的mapper特殊字符轉移及動態SQL條件查詢小結

mybatis的mapper特殊字符轉移及動態SQL條件查詢小結

2022-01-17 12:04kenx Java教程

mybatis mapper文件中條件查詢符,如>=,<,之類是不能直接寫的會報錯的需要轉移一下,本文給大家介紹了常見的條件查詢操作,對mybatis的mapper特殊字符及動態SQL條件查詢相關知識感興趣的朋友一起看看吧

 

前言

我們知道在項目開發中之前使用數據庫查詢,都是基于jdbc,進行連接查詢,然后是高級一點jdbcTemplate進行查詢,但是我們發現還是不是很方便,有大量重復sql語句,與代碼偶合,效率低下,于是就衍生出來ORM框架,如Mybatis,Hibernate,還有SpringBoot的,Spring Data JPA

 

條件查詢

我們知道在mybatis mapper文件中條件查詢符,如>=,<,之類是不能直接寫的會報錯的需要轉移一下 如下圖表

mybatis的mapper特殊字符轉移及動態SQL條件查詢小結

詳細內容參考

常見的條件查詢操作有

mybatis的mapper特殊字符轉移及動態SQL條件查詢小結

我們通過mybatis 提供的特有標簽進行條件判斷,達到動態拼接sql語句

if標簽 where標簽 choose when otherwise標簽 foreach標簽

 

快速入門

 

if標簽

語法:

<if test="xxx != null and xxx != """>

test中寫判斷條件 參數直接paramN或者別名 多個條件使用and或者or連接

只要條件成立就拼接在Sql語句中,都成立就全部都拼接

注意where子句中加上1=1來規避and的風險

如下例子:

<select id="selg" resultType="log">
    select * from log where 1=1
    <if test="param1!=null and param1!=""">
    and outno=#{param1}
    </if>
    <if test="param2!=null and param2!=""">
    and inno=#{param2}
    </if>
</select>

 

where標簽

對上面if標簽條件判斷where連接做了處理會自動的給Sql語句添加where關鍵字,并將第一個and去除

上面sql可以改造成如下:

<select id="selg" resultType="log">
      select * from log 
  <where>
       <if test="param1!=null and param1!=""">
      and outno=#{param1}
      </if>
      <if test="param2!=null and param2!=""">
      and inno=#{param2}
      </if>
  </where>
     
</select>

 

choose when otherwise標簽

類似于Java語法中的,case,switch語句判斷

條件只要有一個成立,其他的就不會再判斷了。如果沒有成立的條件則默認執行otherwise中的內容

上面sql可以改造成如下:

<select id="selg" resultType="log">
      select * from log 
  <where>
    <choose>
       <when test="param1!=null and param1!=""">
      and outno=#{param1}
      </when>
      <when test="param2!=null and param2!=""">
      and inno=#{param2}
      </when>
      <otherwise>
        and 1=1
      </otherwise>
    </choose>
  </where>
     
</select>

 

foreach標簽

語法:

 <foreach collection="idList" item="id" open="(" separator="," close=")">
</foreach>

  • collection:要遍歷的集合對象
  • item:記錄每次遍歷的結果
  • open:在結果的左邊添加內容
  • separator:結果和結果之間的內容
  • close:在最后添加的內容

常用于in查詢,和批量插入操作 如下案例:

<select id="selF" parameterType="list" resultType="account">
    select * from account where ano in
    <foreach collection="list" item="item" open="(" separator="," close=")">
    #{item}
    </foreach>
   </select>


<insert id="insertBatch">
        INSERT INTO t_user
        (id, name, password)
        VALUES
        <foreach collection ="userList" item="user" separator =",">
            (#{user.id}, #{user.name}, #{user.password})
        </foreach >
    </insert>

其他標簽使用參考點擊進入?

 

場景案例

1.當我們需要對多張表的關聯數據進行復雜動態條件查詢的時候,就需要用到 if標簽進行判斷 如下

根據用戶手機號姓名年齡性別,等進行動態條件檢索,這個時候我們需要動態通過調節去拼接sql 當條件滿足sql語句加上對應條件差許

<select id="findUsersByUser" resultType="cn.soboys.kmall.sys.entity.User">
        select tu.USER_ID,tu.USERNAME,tu.SSEX,td.DEPT_NAME,tu.MOBILE,tu.EMAIL,tu.STATUS,tu.CREATE_TIME,
        td.DEPT_ID
        from t_user tu left join t_dept td on tu.DEPT_ID = td.DEPT_ID
        where tu.ADMIN_TYPE_ID  &gt;= 0 AND tu.ADMIN_TYPE_ID  &lt;= #{userParams.adminType}
        <if test="userParams.roleId != null and userParams.roleId != """>
           and (select group_concat(ur.ROLE_ID)
            from t_user u
            right join t_user_role ur on ur.USER_ID = u.USER_ID,
            t_role r
            where r.ROLE_ID = ur.ROLE_ID
            and u.USER_ID = tu.USER_ID and r.ROLE_ID=#{userParams.roleId})
        </if>


        <if test="userParams.mobile != null and userParams.mobile != """>
            AND tu.MOBILE =#{userParams.mobile}
        </if>
        <if test="userParams.username != null and userParams.username != """>
            AND tu.USERNAME   like CONCAT("%",#{userParams.username},"%")
        </if>
        <if test="userParams.ssex != null and userParams.ssex != """>
            AND tu.SSEX  =#{userParams.ssex}
        </if>
        <if test="userParams.status != null and userParams.status != """>
            AND tu.STATUS =#{userParams.status}
        </if>
        <if test="userParams.deptId != null and userParams.deptId != """>
            AND td.DEPT_ID =#{userParams.deptId}
        </if>
        <if test="userParams.createTime != null and userParams.createTime != """>
            AND DATE_FORMAT(tu.CREATE_TIME,"%Y%m%d") BETWEEN substring_index(#{userParams.createTime},"#",1) and substring_index(#{userParams.createTime},"#",-1)
        </if>
    </select>

對應mapper對應的方法

<T> IPage<User> findUsersByUser(Page<T> page, @Param("userParams") SearchUserParams userParams);

對應參數實體對象

@Data
public class SearchUserParams {
    private String username;
    private String mobile;
    private String status;
    private String ssex;
    private Long deptId;
    private String createTime;
    private long adminType;
    private String roleId;
}

通過if標簽去判斷條件是否滿足,滿足就拼接對應sql

注意在上面我們提到的條件拼接第一個是where連接,而不是and應規避and風險保證sql語法正確 如下

<select id="findSearchCouponsPage" parameterType="cn.soboys.kmall.bean.web.params.SearchCouponParams" resultType="coupon">
        select *
        from coupon c
        left join user_coupon uc on c.coupon_id = uc.coupon_id
        WHERE 1 = 1
        <if test="couponParams.userId != null and couponParams.userId != """>
           and uc.user_id =#{couponParams.userId}
        </if>
        <if test="couponParams.status != null and couponParams.status != """>
            and c.status =#{couponParams.status}
        </if>
        <if test="couponParams.couponId != null and couponParams.couponId != """>
            and c.coupon_id =#{couponParams.couponId}
        </if>
        <if test="couponParams.couponType != null and couponParams.couponType != """>
            and c.type =#{couponParams.couponType}
        </if>
    </select>

我們可以通過假定給他一個默認條件 WHERE 1 = 1來解決,也可以通過嵌套where標簽來解決

到此這篇關于mybatis的mapper特殊字符轉移及動態SQL條件查詢的文章就介紹到這了,更多相關mybatis的mapper特殊字符轉移內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://www.cnblogs.com/kenx/p/15329027.html

延伸 · 閱讀

精彩推薦
  • Java教程Java BufferWriter寫文件寫不進去或缺失數據的解決

    Java BufferWriter寫文件寫不進去或缺失數據的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數據的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經有好久沒有升過級了。升級完畢重啟之后,突然發現好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發現了對于集合操作轉換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關于Java8中S...

    阿杜7482021-02-04
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關于小米推送Java代碼,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩中求8032021-07-12
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

    這篇文章主要介紹了xml與Java對象的轉換詳解的相關資料,需要的朋友可以參考下...

    Java教程網2942020-09-17
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
主站蜘蛛池模板: 俄罗斯处女摘花 | 国产自精品| 青柠影视在线播放观看高清 | 亚洲第一色区 | 亚洲国产天堂综合一区 | 91精品啪在线观看国产91九色 | 二区三区不卡不卡视频 | 免费视屏 | 天若有情1992国语版完整版 | 成年人福利 | 亚洲区精品久久一区二区三区 | 兽皇videos日本另类 | 校花小雪灌满了男人们的浓浆 | 欧美日韩高清完整版在线观看免费 | 午夜神器18以下不能进免费 | 女教师系列三上悠亚在线观看 | 99热碰| 国产一区二区免费福利片 | 午夜深情在线观看免费 | 亚洲网站在线 | 国产馆精品推荐在线观看 | 天堂avav| 国产精品最新资源网 | 国产精品亚洲片夜色在线 | 免费视频网 | 成品人视频免费观看 | 欧美日韩国产亚洲一区二区三区 | 亚洲国产精品久久丫 | 精品国产成人a区在线观看 精品高潮呻吟99AV无码视频 | 国产精品免费视频能看 | 免费一区在线观看 | 韩国三级在线 | 美女机机对机机的视频(免费) | 青青草原手机在线视频 | 国产一二在线观看视频网站 | 美女乳液| 日本艳鉧动漫1~6完整版在 | 亚洲人成毛片线播放 | 天堂资源在线8 | 欧美日韩一区二区三区免费不卡 | 亚洲 欧美 清纯 校园 另类 |