首頁 Java java教程 基於Spring Boot和MyBatis Plus實作ORM映射

基於Spring Boot和MyBatis Plus實作ORM映射

Jun 22, 2023 pm 09:27 PM
spring boot orm映射 mybatis plus

在Java web應用開發過程中,ORM(Object-Relational Mapping)映射技術用來將資料庫中的關係型資料對應到Java物件中,方便開發者進行資料存取與操作。 Spring Boot作為目前最受歡迎的Java web開發框架之一,已經提供了整合MyBatis的方式,而MyBatis Plus則是在MyBatis的基礎上擴展的一種ORM框架。本文將介紹如何使用Spring Boot和MyBatis Plus來實現ORM映射。

一、Spring Boot整合MyBatis Plus
在Spring Boot中使用MyBatis Plus非常簡單,只需在maven中加入MyBatis Plus的依賴即可。

<dependency>
  <groupId>com.baomidou</groupId>
  <artifactId>mybatis-plus-boot-starter</artifactId>
  <version>3.4.2</version>
</dependency>
登入後複製

同時,在application.properties或application.yml中配置MyBatis Plus相關參數,如下:

#数据库配置
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/mybatis_plus?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=123456
#MyBatis Plus配置
mybatis.configuration.cache-enabled=false
mybatis.mapper-locations=classpath:mapper/*.xml
登入後複製

其中,driver-class-name, url, username和password是資料庫相關配置,而mapper-locations是MyBatis Plus的SQL映射設定檔所在的路徑。

二、定義實體類別和Mapper介面
和MyBatis一樣,使用MyBatis Plus也需要定義實體類別和Mapper介面。下面以一個簡單的User表為例,定義對應的實體類別和Mapper介面。

  1. 定義實體類別
@Getter
@Setter
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class User {

    private Integer id;
    private String name;
    private Integer age;
    private String email;
    private Integer gender;
    private LocalDateTime createTime;
    private LocalDateTime updateTime;

}
登入後複製

使用註解@Getter、@Setter和@Builder可以簡化程式碼,而@NoArgsConstructor和@AllArgsConstructor是用來產生無參和全參構造函數的。

  1. 定義Mapper介面
public interface UserMapper extends BaseMapper<User> {
}
登入後複製

這裡使用了MyBatis Plus提供的BaseMapper,可以省去許多繁瑣的SQL作業。

三、使用MyBatis Plus進行資料庫操作
在定義完Mapper介面後,就可以使用MyBatis Plus來進行資料庫操作了。

  1. 插入資料
User user = User.builder()
        .name("test")
        .age(20)
        .email("test@test.com")
        .gender(1)
        .createTime(LocalDateTime.now())
        .updateTime(LocalDateTime.now())
        .build();
int count = userMapper.insert(user);
登入後複製

在插入資料時,可以直接使用Mapper介面中提供的insert方法,MyBatis Plus會自動將實體類別的屬性對應到資料庫中的對應列。

  1. 查詢資料
List<User> userList = userMapper.selectList(null);
登入後複製

在查詢資料時,可以直接使用Mapper介面中提供的selectList方法,傳入null或一個空的QueryWrapper物件即可查詢出所有數據。另外,還可以使用MyBatis Plus提供的lambda表達式和鍊式操作來進行更為複雜的查詢,如下所示:

QueryWrapper<User> wrapper = Wrappers.<User>lambdaQuery()
        .eq(User::getGender, 1)
        .ge(User::getAge, 20)
        .orderByDesc(User::getCreateTime);
List<User> userList = userMapper.selectList(wrapper);
登入後複製

在上述程式碼中,使用Wrappers.lambdaQuery()定義了一個QueryWrapper對象,並且透過.eq、.ge和.orderByDesc鍊式操作來建構查詢條件和排序規則。

  1. 更新數據
User user = userMapper.selectById(id);
user.setAge(30);
int count = userMapper.updateById(user);
登入後複製

在更新數據時,可以先透過selectById查詢出需要更新的數據,然後對需要更新的屬性進行修改,並使用updateById將修改後的資料更新到資料庫中。

  1. 刪除資料
int count = userMapper.deleteById(id);
登入後複製

最後,在刪除資料時,只需呼叫Mapper介面中提供的deleteById方法即可。

四、結論
本文介紹如何使用Spring Boot和MyBatis Plus來實現ORM映射,透過簡單的設定和程式碼即可實現資料庫操作。 MyBatis Plus作為MyBatis的延伸框架,可以大幅簡化開發人員的工作量,同時提升程式碼的可讀性和可維護性。由於篇幅所限,本文只對MyBatis Plus的基本用法進行了介紹,更多進階功能請參考官方文件。

以上是基於Spring Boot和MyBatis Plus實作ORM映射的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Spring Boot+MyBatis+Atomikos+MySQL(附源碼) Spring Boot+MyBatis+Atomikos+MySQL(附源碼) Aug 15, 2023 pm 04:12 PM

我們在實際專案中,盡量規避分散式事務。但是,有些時候是真的需要做一些服務拆分從而會引出分散式事務問題。同時,分散式事務也是面試中市場被問到,可以拿著這個案例練練手,面試就可以說上個123了。

透過Spring Boot實現多語言支援和國際化應用 透過Spring Boot實現多語言支援和國際化應用 Jun 23, 2023 am 09:09 AM

隨著全球化的發展,越來越多的網站和應用需要提供多語言支援和國際化功能。對於開發人員而言,實現這些功能並不是一件容易的事情,因為它需要考慮許多方面的問題,例如語言的翻譯、日期、時間和貨幣格式等等。但是,使用SpringBoot框架,我們可以輕鬆實現多語言支援和國際化應用。首先,讓我們來了解一下SpringBoot提供的LocaleResolver介面。 Loc

如何使用Spring Boot建立大數據處理應用 如何使用Spring Boot建立大數據處理應用 Jun 23, 2023 am 09:07 AM

隨著大數據時代的到來,越來越多的企業開始了解並認識到大數據的價值,並將其運用到商業中。而隨之而來的問題就是如何處理這些大流量的數據。在這種情況下,大數據處理應用程式成為了每個企業必須考慮的事情。而對於開發人員而言,如何使用SpringBoot建立一個高效的大數據處理應用程式也是一個非常重要的問題。 SpringBoot是一個非常流行的Java框架,它可以讓

基於Spring Boot和MyBatis Plus實作ORM映射 基於Spring Boot和MyBatis Plus實作ORM映射 Jun 22, 2023 pm 09:27 PM

在Javaweb應用程式開發過程中,ORM(Object-RelationalMapping)映射技術用來將資料庫中的關係型資料對應到Java物件中,方便開發者進行資料存取與操作。 SpringBoot作為目前最受歡迎的Javaweb開發框架之一,已經提供了整合MyBatis的方式,而MyBatisPlus則是在MyBatis的基礎上擴展的一種ORM框架。

Spring Boot與NoSQL資料庫的整合使用 Spring Boot與NoSQL資料庫的整合使用 Jun 22, 2023 pm 10:34 PM

隨著網路的發展,大數據分析和即時資訊處理成為了企業的重要需求。為了滿足這樣的需求,傳統的關係型資料庫已經不再滿足業務和技術發展的需要。相反,使用NoSQL資料庫已經成為了一個重要的選擇。在這篇文章中,我們將討論SpringBoot與NoSQL資料庫的整合使用,以實現現代應用程式的開發和部署。什麼是NoSQL資料庫?NoSQL是notonlySQL

使用Spring Boot和Apache ServiceMix建置ESB系統 使用Spring Boot和Apache ServiceMix建置ESB系統 Jun 22, 2023 pm 12:30 PM

隨著現代企業越來越依賴各種不同的應用程式和系統,企業整合變得愈發重要。企業服務匯流排(ESB)就是一種整合架構模式,透過將不同系統和應用程式連接在一起,提供通用的資料交換和訊息路由服務,從而實現企業級應用程式整合。使用SpringBoot和ApacheServiceMix,我們可以輕鬆建立一個ESB系統,這篇文章將介紹如何實作。 SpringBoot和A

使用Spring Boot和JavaFX建立桌面應用程式 使用Spring Boot和JavaFX建立桌面應用程式 Jun 22, 2023 am 10:55 AM

隨著技術的不斷發展,我們現在可以使用不同的技術來建立桌面應用程式。而SpringBoot和JavaFX則是現在較為流行的選擇之一。本文將重點放在如何使用這兩個框架來建立一個功能豐富的桌面應用程式。一、介紹SpringBoot和JavaFXSpringBoot是基於Spring框架的快速開發框架。它可以幫助開發者快速建立Web應用程序,同時提供一組開

Spring Boot 實作 MySQL 讀寫分離技術 Spring Boot 實作 MySQL 讀寫分離技術 Aug 15, 2023 pm 04:52 PM

如何實現讀寫分離,Spring Boot項目,資料庫是MySQL,持久層用的是MyBatis。

See all articles