【java框架】MyBatis(2)--Mapper代理介面及批量操作

来源:https://www.cnblogs.com/yif0118/archive/2020/03/22/12548587.html
-Advertisement-
Play Games

1. Mapper映射代理介面 MyBatis基於代理機制,可以讓我們無需在編寫Dao層的介面,我們可以把以前的Dao層的IXxxDao介面直接定義成符合規則的Mapper介面。 具體實現步驟如下: ① 在項目mapper文件目錄下創建對應的Mapper介面,介面命令必須是以Mapper結尾,名字是 ...


1.   Mapper映射代理介面

MyBatis基於代理機制,可以讓我們無需在編寫Dao層的介面,我們可以把以前的Dao層的IXxxDao介面直接定義成符合規則的Mapper介面。

具體實現步驟如下:

①    在項目mapper文件目錄下創建對應的Mapper介面,介面命令必須是以Mapper結尾,名字是Domain類名+Mapper;

 

 

②    在項目mapper文件的同級目錄下創建Domain類名+Mapper.xml文件,註意必須與Mapper介面建立關係,通過namespace要能找到mapper介面;

 

 

③    在DomainMapper.xml文件中編寫sql語句,註意各個sql語句的id要和DomainMapper介面中的方法名一致,返回值、參數類型也要一致;

 

 

 

④    編寫測試Junit類,可以看到對應的Mapper介面已經變成了一個代理,對應的數據通過代理mapper介面獲取;

 

 

2.   MyBatis的批量操作(添加、刪除)

2.1.批量添加

批量添加首先構造一個對應批量處理添加的sql語句:

Insert into user(username, password) values (?, ?), (?, ?), (?, ?)

根據這個結構我們需要對應編寫介面與.xml中配置Sql語句,這裡需要使用到<foreach>標簽。

UserMapper介面:

public interface UserMapper {
    void insertBatch(List<User> userList);
}

UserMapper.xml配置:

<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- namespace:這裡使用Mapper映射代理介面,namespace對應mapper介面文件 -->
<mapper namespace="cn.yif.mybatis.mapper.UserMapper">
   <!--測試批量添加user,需要構造批量添加SQL-->
   <insert id="insertBatch" parameterType="java.util.List">
        insert into user(username, password) values
       <foreach collection="list" index="index" item="user" separator=",">
            (#{user.name}, #{user.pwd})
       </foreach>
   </insert>
</mapper>

編寫測試類:

public class UserMapperTest {
   @Test
   public void insertBatch(){
       SqlSession sqlSession = MyBatisUtil.getSqlSession();
       UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
       List<User> userList = new ArrayList<>();
       userList.add(new User("李軍", "4523"));
       userList.add(new User("吳華", "3257"));
       userList.add(new User("王慧", "5200"));
       userMapper.insertBatch(userList);
       //註意:使用Mapper介面代理對象時必須提交SqlSession,即必須調用commit方法,否則添加數據無法同步到資料庫
       sqlSession.commit();
       sqlSession.close();
   }
}

2.2.批量刪除

首先構造一個批量刪除的Sql語句:

delete from user where id in (?, ?, ?, ?)

同樣需要在UserMappper.xml中配置批量刪除的Sql語句,如下:

<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- namespace:這裡使用Mapper映射代理介面,namespace對應mapper介面文件 -->
<mapper namespace="cn.yif.mybatis.mapper.UserMapper">
   <!--測試批量刪除user-->
   <!--delete from user where id in (25, 26, 27, 29)-->
   <delete id="deleteBatch" parameterType="java.util.List">
       delete from user where id in
       <foreach collection="list" index="index" item="id" open="(" separator="," close=")">
            #{id}
       </foreach>
   </delete>
</mapper>

對應UserMapper介面中添加批量刪除介面方法:

public interface UserMapper {
    void deleteBatch(List<Integer> idLst);
}

編寫對應測試類:

public class UserMapperTest {
   @Test
   public void deleteBatch(){
       SqlSession sqlSession = MyBatisUtil.getSqlSession();
       UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
       List<Integer> idsLst = new ArrayList();
       idsLst.add(16);
       idsLst.add(17);
       idsLst.add(18);
       userMapper.deleteBatch(idsLst);
       //註意:使用Mapper介面代理對象時必須提交SqlSession,即必須調用commit方法,否則刪除數據無法同步到資料庫
       sqlSession.commit();
       sqlSession.close();
   }
}

2.3.<foreach>標簽屬性介紹

在批量刪除與批量添加配置Sql中都使用到了<foreach>標簽,這裡說明一下foreach標簽中的屬性:collection、item、separator、index、open、close。

1.collection:指定要遍歷的集合。表示傳入過來的參數的數據類型。該屬性是必須要指定的,要做foreach的對象。在使用foreach的時候最關鍵最容易出錯的就是collection屬性。在不同情況下,該屬性的值是不一樣的,主要有以下3種情況:

   a.如果傳入的是單參數且參數類型是一個List的時候,collection屬性值為list;

   b.如果傳入的是單參數且參數類型是一個array數組的時候,collection屬性值為array;

   c.如果傳入的參數是多個的時候,我們就需要把它們封裝成一個Map了,當然單參數也可以封裝成Map。Map對象沒有預設的鍵。

2.item:表示集合中每一個元素進行迭代時的別名。將當前遍歷出的元素賦值給指定的變數,然後用#{變數名},就能取出變數的值,也就是當前遍歷出的元素。

3.  separator:表示在每次進行迭代之間以什麼符號作為分隔符。Select * from table where id in (1, 2, 3),相當於1,2,3之間的”,”。

4.  index:索引。Index指定一個名字,用於表示在迭代過程中,每次迭代到的位置。遍歷list的時候index就是索引,遍歷map的時候index表示的就是map的key,item就是map的值。

5.  open表示該語句以什麼開始,close表示以什麼結束。

以上具體參數屬性說明參考:http://www.imooc.com/article/details/id/284701


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • [TOC] 環境 idea 2019.1 Meavn 3.6.0 SpringBoot 2.2.5 jdk 1.8 構建eureka server 新建工程 啟動類添加註解 @EnableEurekaServer 其他配置 構建eureka client 新建工程 pom文件添加依賴,解決啟動失敗 ...
  • 距離Java 8發佈已經過去了7、8年的時間,Java 14也剛剛發佈。Java 8中關於函數式編程和新增的Stream流API至今飽受“爭議”。 如果你不曾使用Stream流,那麼當你見到Stream操作時一定對它發出過鄙夷的聲音,併在心裡說出“這都寫的什麼玩意兒”。 如果你熱衷於使用Stream ...
  • 恢復內容開始 1.背景:現在很多app或者網站都想要接入微信登錄,可以使用戶不需要註冊就能快速使用APP或網站。 2.微信登錄需要一些前置操作 2.1 搜索:微信開放平臺 鏈接:https://open.weixin.qq.com/ 2.2 註冊成功,獲取到開發所需要的appID和appsecret ...
  • elastic4s是elasticsearch一個第三方開發的scala語言終端工具庫(Elastic4s is a concise, idiomatic, reactive, type safe Scala client for Elasticsearch.)。scala用戶可以用elastic4 ...
  • 1. 不可變的PyIntObject "Python源碼剖析 對象初探" 我們對 PyIntObject 已經有了初步的瞭解。 Python 中的對象可以分為固定長度和可變長度兩種類型。除此之外,也可以按照可變和不可變進行劃分。 PyIntObject 則屬於長度固定且不可變的對象。相比其他的對象而 ...
  • 【qdox】Java 代碼解析利器 QDox 前言 最近在寫 maven 插件,涉及到了 java 代碼解析這塊內容。需要解析 java 源碼,然後對於類中的不同部分進行處理。發現手寫還是很難的,找了一圈發現了兩個不錯的工具可以使用,一個是 "javaparser" ,另一個是 "qdox" 。個人 ...
  • xlrd openpyxl 庫 應該是自帶了,反正我是沒安裝,csv也可製作表格,關於csv以後介紹 基本操作 import xlrd book = xlrd.open_workbook('filename') book.nsheets # 表單數量 book.sheet_names() # 表單名 ...
  • 通過Windows命令行編譯運行C語言源文件 1. 檢查C語言的編譯環境是否配置成功 + win+r 輸入 打開dos視窗,輸入命令 ,查看是否有內容輸出 + 如果有以下內容輸出,則說明配置成功,可以進行下一步 + 如果輸入該命令後,dos視窗輸出以下內容 則說明編譯環境配置失敗,需要重新配置 + ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...