=, "/>

国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

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

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
主站蜘蛛池模板: 99热视 | 欧美色涩| 欧美三级在线 | 亚洲在线播放 | 免费福利视频一区二区三区 | 国产成人精品一区二区三区四区 | 国产精品福利电影网 | 日本中文字幕在线 | 香蕉福利视频 | 国产一区不卡 | 午夜精品久久久久 | 国产精品久久久久一区二区三区 | 色一色网站 | 成人午夜精品久久久久久久3d | 精品小视频 | 男人天堂av网 | 国产啊女在线观看 | 免费的一级视频 | 久草天堂 | 亚洲欧美一区二区三区在线 | 1区2区在线观看 | 成人免费影院 | 亚洲一区二区三区视频 | 亚洲免费国产 | 网站黄色在线 | 国产一区二区三区在线 | 久久人人av| 爱色影wwwcom| 色综合天天综合网国产成人综合天 | 久久久www成人免费无遮挡大片 | 荷兰欧美一级毛片 | 免费一级毛片 | 亚洲毛片在线观看 | 久久久精品免费观看 | 日韩欧美中文字幕在线视频 | 欧美日韩综合 | 中文字幕1区2区3区 亚洲欧美日韩精品久久亚洲区 | 久久久成人精品 | 日韩在线视频免费观看 | 亚洲一区二区免费视频 | 91久久国产综合久久 |