搜索
首页Javajava教程基于Spring Boot和MyBatis Plus实现ORM映射

基于Spring Boot和MyBatis Plus实现ORM映射

Jun 22, 2023 pm 09:27 PM
spring bootorm映射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.4c8e0c17c3bd7e0081bb17cc795e1984lambdaQuery()定义了一个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
Java平台独立性:与不同的操作系统的兼容性Java平台独立性:与不同的操作系统的兼容性May 13, 2025 am 12:11 AM

JavaachievesPlatFormIndependencethroughTheJavavIrtualMachine(JVM),允许Codetorunondifferentoperatingsystemsswithoutmodification.thejvmcompilesjavacodeintoplatform-interploplatform-interpectentbybyteentbytybyteentbybytecode,whatittheninternterninterpretsandectectececutesoneonthepecificos,atrafficteyos,Afferctinginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginging

什么功能使Java仍然强大什么功能使Java仍然强大May 13, 2025 am 12:05 AM

JavaispoperfulduetoitsplatFormitiondence,对象与偏见,RichstandardLibrary,PerformanceCapabilities和StrongsecurityFeatures.1)Platform-dimplighandependectionceallowsenceallowsenceallowsenceallowsencationSapplicationStornanyDevicesupportingJava.2)

顶级Java功能:开发人员的综合指南顶级Java功能:开发人员的综合指南May 13, 2025 am 12:04 AM

Java的顶级功能包括:1)面向对象编程,支持多态性,提升代码的灵活性和可维护性;2)异常处理机制,通过try-catch-finally块提高代码的鲁棒性;3)垃圾回收,简化内存管理;4)泛型,增强类型安全性;5)ambda表达式和函数式编程,使代码更简洁和表达性强;6)丰富的标准库,提供优化过的数据结构和算法。

Java真的平台独立吗? '写一次,在任何地方运行”如何起作用Java真的平台独立吗? '写一次,在任何地方运行”如何起作用May 13, 2025 am 12:03 AM

javaisnotirelyPlatemententduetojvmvariationsandnativecodinteintration,butitlargelyupholdsitsitsworapromise.1)javacompilestobytecoderunbythejvm

揭示JVM:您了解Java执行的关键揭示JVM:您了解Java执行的关键May 13, 2025 am 12:02 AM

thejavavirtualmachine(JVM)IsanabtractComputingmachinecrucialforjavaexecutionasitrunsjavabytecode,使“ writeononce,runanywhere”能力

Java仍然是基于新功能的好语言吗?Java仍然是基于新功能的好语言吗?May 12, 2025 am 12:12 AM

Javaremainsagoodlanguageduetoitscontinuousevolutionandrobustecosystem.1)Lambdaexpressionsenhancecodereadabilityandenablefunctionalprogramming.2)Streamsallowforefficientdataprocessing,particularlywithlargedatasets.3)ThemodularsystemintroducedinJava9im

是什么使Java很棒?关键特征和好处是什么使Java很棒?关键特征和好处May 12, 2025 am 12:11 AM

Javaisgreatduetoitsplatformindependence,robustOOPsupport,extensivelibraries,andstrongcommunity.1)PlatformindependenceviaJVMallowscodetorunonvariousplatforms.2)OOPfeatureslikeencapsulation,inheritance,andpolymorphismenablemodularandscalablecode.3)Rich

前5个Java功能:示例和解释前5个Java功能:示例和解释May 12, 2025 am 12:09 AM

Java的五大特色是多态性、Lambda表达式、StreamsAPI、泛型和异常处理。1.多态性让不同类的对象可以作为共同基类的对象使用。2.Lambda表达式使代码更简洁,特别适合处理集合和流。3.StreamsAPI高效处理大数据集,支持声明式操作。4.泛型提供类型安全和重用性,编译时捕获类型错误。5.异常处理帮助优雅处理错误,编写可靠软件。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )专业的PHP集成开发工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境