【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
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...