MyBatis筆記04-----分頁查詢、resultMap的簡單使用

来源:https://www.cnblogs.com/hytstruggle/archive/2022/11/07/16859296.html
-Advertisement-
Play Games

分頁查詢 1、分頁查詢的好處 MyBatis作為持久層框架,主要任務就是操作資料庫,即是對數據的增、刪、查、改,其中大多數業務是查詢功能,這也是這四個操作中最常用操作。所以為了減少資料庫的負擔,我們使用對數據進行分頁查詢,這樣的話在面對查詢大量數據時,每次只需要查詢小部分數據,隨之查詢的次數隨增加了 ...


分頁查詢

1、分頁查詢的好處

MyBatis作為持久層框架,主要任務就是操作資料庫,即是對數據的增、刪、查、改,其中大多數業務是查詢功能,這也是這四個操作中最常用操作。所以為了減少資料庫的負擔,我們使用對數據進行分頁查詢,這樣的話在面對查詢大量數據時,每次只需要查詢小部分數據,隨之查詢的次數隨增加了。

2、使用分頁的方式

第一種(常用):使用LIMIT

通用語法:

select * from [表名] limit stratIndex,pageSize;

stratIndex:開始下標

pageSize:一頁的大小

如:select * from stu limit 5,10;

表示:查詢表中的第6個數據,保存10條記錄

特殊語法

  • select * from [表名] limit startIndex,-1;

stratIndex:開始下標

-1:表示查詢到最後一條數據結束

如:select * from stu limit 15,-1;

表示:查詢表中數據從第16個數據開始到表中最後一條數據為止

  • select * from [表名] limit 0,pageSize;

0:從表中第一條數據開始查詢

pageSize:一頁的大小

如:select * from stu limit 5;

表示:查詢表中前5條記錄

3、使用分頁的例子

  • StuMapper1介面

 

 /**
     * 分頁查詢
     * @param map 傳入分頁中的stratIndex,pageSize參數(使用map傳入比較方便)
     * @return 返回查詢的結果
     */
    List<Stu1> selectLimit1(Map<String,Object> map);

 

  • StuMapper1.xml文件
<mapper namespace="com.dao.StuMapper1">
    <select id="selectLimit1" parameterType="map" resultType="stu1">
       select * from stu limit #{stratIndex},#{pageSize};
    </select>
</mapper>
  • 在核心配置文件中註冊mapper
 <mappers>
      <mapper resource="com/dao/StuMapper1.xml"/>
    </mappers>
  • 測試
    @Test
    public void test01(){
        SqlSession sqlSession = MybatisUntils.getSqlSession();
        StuMapper1 mapper = sqlSession.getMapper(StuMapper1.class);
        Map<String,Object> map = new HashMap<>();
        map.put("stratIndex",0);
        map.put("pageSize",1);
        List<Stu1> stus = mapper.selectLimit1(map);
        for (Stu1 stu:stus) {
            System.out.println(stu);
        }
        sqlSession.close();
    }

對於上面傳參是Map集合---------萬能Map集合

上面的StuMapper介面也可以寫為

List<Stu1> selectLimit(int stratIndex,int pageSize)

當有多個參數的時候,可以嘗試著使用Map集合作為參數,如果參數比較少的話,直接傳參即可

 

resultMap標簽的簡單使用

1、為什麼使用<resultMap>

答:當實體類中的屬性名和表中的欄位名不一致時需要使用resultMap,使用它的目的是為了映射(描述)實體類中的屬性名和表中欄位名的關係

2、例子:當實體類中的屬性名和表中欄位不一致時會出現的問題:

  • 表中欄位:

  • 實體類中屬性:關註屬性password
@Alias("stu1")
@Data
public class Stu1 {
    private int sno;
    private String sname;
    private int sage;
    private String saddress;
    private String password;//在表中的欄位是spwd,與表中的欄位不一致
}
  • 查詢所有學生信息

StuMapper1介面

List<Stu1> selectAll();

StuMapper.xml文件

 <select id="selectAll" resultType="stu1">
        select * from stu
    </select>
  • 測試結果
  @Test
    public void test02(){
        SqlSession sqlSession = MybatisUntils.getSqlSession();
        StuMapper1 mapper = sqlSession.getMapper(StuMapper1.class);
        List<Stu1> stus = mapper.selectAll();
        for (Stu1 stu:stus) {
            System.out.println(stu);
        }
        sqlSession.close();
    }

 

 

 這種結果明顯和我們想要的結果是不一樣的,出現這種結果的原因:

  在執行select * from stu語句時,會查詢得到資料庫中的學生信息結果集,然後將得到的學生信息結果集 找到對應的實體類,通過對應的set方法把結果集來賦值給類中的屬性,然而這裡只有setPassword(),找不到對應的setSpwd()所以password為null。

3、解決方案有二種

第一種:自動映射(在SQL映射語句使用as)

 <select id="selectAll" resultType="stu1">
        select sno,sname,sage,saddress,spwd as password from stu
 </select>

as:給表中欄位起別名,即將表中的欄位名起別名為java實體類中的屬性名,

第二種:手動映射(使用resultMap)(推薦使用)

<select id="selectAll" resultMap="stuResult">
        select * from stu
    </select>
    <resultMap id="stuResult" type="stu1">
        <id property="sno" column="sno"/>
        <result property="sname" column="sname"/>
        <result property="sage" column="sage"/>
        <result property="saddress" column="saddress"/>
        <result property="password" column="spwd"/>
    </resultMap>

主要就是用<resultMap>來描述類中的屬性名和資料庫表中欄位名之間的關係即可。若是自動映射和手動映射一起使用,則先是自動映射再是手動映射。

resultMap的簡單介紹

1、概述

  • resultMap是mybatis最重要最強大的元素,它可以讓你從90%的JDBC ResultSets結果集數據提取數據代碼中解放出來,而且它可以完成一些操作是JDBC不支持的操作。當編寫一些比較複雜SQL映射語句代碼時(如:多表聯繫查詢),一份resultMap可以實現同功能的數長達千行代碼。
  • resultMap設計思想:簡單的SQL映射語句不需要用到resultMap,複雜的SQL映射語句只需要通過resultMap來描述他們之間的關係即可

2、resultMap中的屬性

id屬性:唯一標識,它的值==如<select>、<insert>、<update>、<delete>.......中resultMap屬性值

type屬性:是id值代表的類型(通常都是javaBean類型)

3、resultMap的子標簽

每個子標簽中都有property、column屬性,其中property是用來描述實體類中的屬性,column是用來描述資料庫表中的欄位(列)名,這兩個屬性完成了實體類與表之間的關係映射。

<id>:用來描述資料庫表中主鍵。

<result>:用來描述資料庫中非主鍵。

這隻是resultMap中簡單介紹,在後面中會出現一對多,多對一的情況,那時候那就是更複雜的SQL映射語句了,需要用到resultMap,當然那時候並不是這麼簡單的使用resultMap。(在MyBatis筆記6中介紹)

 


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

-Advertisement-
Play Games
更多相關文章
  • 1.Python條件語句 Python條件語句是通過一條或多條語句的執行結果(True或者False)來決定執行的代碼塊。 可以通過下圖來簡單瞭解條件語句的執行過程: Python程式語言指定任何非0和非空(null)值為true,0 或者 null為false。 Python 編程中 if 語句用 ...
  • 插值查找演算法 插值查找原理介紹: ​ 插值查找演算法類似於二分查找,不同的是插值查找每次從自適應 mid 處開始查找。 2.將折半查找中的求 mid 索引的公式 , low 表示左邊索引 left, high 表示右邊索引 right. key 就是前面我們講的 findVal int mid = l ...
  • ##Alibaba Cloud 簡介 Spring Cloud Alibaba 即 Alibaba Cloud ,基於 Spring Cloud 構建,同時封裝了阿裡巴巴的 Nacos、Sentinel 等組件。 由於 Netflix 早期提供的 Eureka、Zuul、Hystrix 等組件早已停 ...
  • 前言 嗨嘍~大家好呀,這裡是魔王吶 ! 最近鄰 (k Nearest Neighbors, KNN)演算法是一種分類演算法 1968年由Cover和Hart提出,應用場景有寧符識別、文本分類、 圖像識別等領域。 手寫數字識別是一個經典的機器學習問題,通過識別手寫體圖片來判斷數字 因為數字類別是0——9, ...
  • 哈嘍,兄弟們,今天讓我們一起來重溫一下Python基礎中的列表,看看你還記得多少呢? 列表是什麼 列表有一系列特定順序排列的元素組成。可以包含字母表中的所有字母,數字等。其中的元素之間可以沒有任何聯繫,列表通常包含多種元素。 在Python中用方括弧([])表示列表,用逗號分隔其中的元素。 a=[' ...
  • Bugs mux2 原本代碼的邏輯是反的,這不是坑人嗎。 module top_module ( input sel, input [7:0] a, input [7:0] b, output [7:0]out ); assign out = ({8{sel}} & a) | ({8{~sel}} ...
  • 問題描述 在大型項目中,通常存在多個模塊,模塊對外暴露的功能通常是通過介面封裝,這樣可以明確模塊的功能,有效降低模塊與模塊之間的耦合度,同時模塊與模塊之間進行合理的組裝。介面的實現,有時可能存在多個實現,如介面每個實現對應一種策略、或者測試代碼中因為測試場景添加了測試實現等,這時候如果想給介面添加一 ...
  • GO語言的環境安裝 下載地址 Go下載 - Go語言中文網 - Golang中文社區 (studygolang.com) 安裝 這裡很簡單,可以一直點下一步就可以了 環境搭建 我這裡也是去D盤當中創建一個專門用來存儲環境地址的文件夾Environment 在Environment創建一個Go語言的環 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...