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
  • 一:背景 1. 講故事 這一期程式故障除了做原理分析,還順帶吐槽一下,熟悉我的朋友都知道我分析dump是免費的,但免費不代表可以濫用我的寶貴時間,我不知道有些人故意惡搞卡死是想幹嘛,不得而知,希望後面類似的事情越來越少吧!廢話不多說,我們來看看是如何被惡搞的。 二:WinDbg 分析 1. 程式是如 ...
  • TCP(Transmission Control Protocol): 特點:面向連接、可靠傳輸、按序交付、流量控制、擁塞控制。 用途:適用於需要高可靠性的數據傳輸,如網頁瀏覽、電子郵件、文件傳輸等。 優勢:數據包順序和完整性有保障,適合需要準確無誤傳輸數據的場景。 舉例:線上購物網站的交易數據傳輸 ...
  • 前面兩篇隨筆介紹了EAV模型(實體-屬性-值)的設計思路和Winform前端對於通用查詢的處理,本篇隨筆繼續深入EAV模型(實體-屬性-值)設計的探討,介紹實體屬性的定義,以及根據不同屬性的定義構建不同的輸入控制項處理,以及列表界面的展示。旨在結合關係型資料庫的熟練使用、性能優勢和MongoDB資料庫... ...
  • IEC60870-5-104 是一種電力自動化系統中常用的通信協議,使用 TCP/IP 協議作為底層通信協議,用於監視和控制電力系統中的各種設備,如變電站、發電機、開關等。 ...
  • 前言:最近幾天有好幾個小伙伴玩WPF,遇到不同頁面,不知道要怎麼傳遞消息。於是,我今天就來演示一個事件聚合器的玩法,採用prism框架來實現。作為福利,內容附帶了主頁面打開對話框時候直接通過參數傳遞消息的一個小例子,具體請自行圍觀。 以下內容,創建wpf項目以及引用prism和實現依賴註入等細節,可 ...
  • 在這篇文章中,我們介紹瞭如何利用大型語言模型為情人節營造難忘的氛圍。通過上傳圖片併進行風格轉化,我們可以為對方呈現一幅獨特的作品,增添浪漫的色彩。同時,藉助搜索功能,我們能夠輕鬆獲取與情人節相關的信息,為策劃活動提供更多靈感和建議。 ...
  • 正文 晚上跳舞回來,在便利店照例買根冰淇淋吃。看到店裡的老闆娘在訓她孩子。言辭依稀可以聽見考上好初中之類。 當時一個臨時起意,打算買兩根冰淇淋,塞一根到他手上,說一句:“我小時候也老被罵,沒什麼。” 然後跑掉。但是在冰櫃里翻了半天,都沒找到自己想吃的那種。與此同時,聽到他媽媽聲色俱厲地說:“你知道我小時 ...
  • strcpy和memcpy 目錄strcpy和memcpy 複製內容: strcpy:專門用於複製字元串,它會一直複製直到遇到源字元串中的'\0'結束符。這意味著如果源字元串長度超過了目標緩衝區的大小(不包括'\0'),就會發生緩衝區溢出,這是一個常見的安全隱患。 memcpy:可以複製任意內容,如 ...
  • 本文介紹在Visual Studio中,通過屬性表,使得一個新建解決方案中的項目可以快速配置已有解決方案的項目中各類已編譯好的C++第三方庫的方法~ ...
  • 將多個第三方包封裝成一個項目後,如果你的目的是讓其他開發人員可以直接引用這些依賴,一般來說有兩種常見的方式: 打成JAR包:將封裝好的項目編譯打包成JAR文件,其他開發人員可以將這個JAR文件添加到他們的項目中,併在項目的構建工具(比如Maven)中配置該JAR作為依賴。這樣做的好處是簡單直接,其他 ...