Spring Boot学习随笔- 集成MyBatis-Plus,第一个MP程序(环境搭建、@TableName、@TableId、@TableField示例)

本文主要是介绍Spring Boot学习随笔- 集成MyBatis-Plus,第一个MP程序(环境搭建、@TableName、@TableId、@TableField示例),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

学习视频:【编程不良人】Mybatis-Plus整合SpringBoot实战教程,提高的你开发效率,后端人员必备!

引言

MyBatis-Plus是一个基于MyBatis的增强工具,旨在简化开发,提高效率。它扩展了MyBatis的功能,提供了许多实用的特性,包括强大的CRUD操作、条件构造器、分页插件、代码生成器等。MyBatis-Plus的目标是简化开发,提供更便捷的操作数据库的方式。

MyBatis-Plus的主要特性包括:

  1. CRUD操作的增强功能:MyBatis-Plus提供了丰富的CRUD操作方法,包括批量插入、批量更新、链式查询等,简化了数据操作的流程。
  2. 条件构造器:MyBatis-Plus内置了条件构造器,可以通过简单的方法链式调用来构建复杂的查询条件,避免手写SQL语句,提高了开发效率。
  3. 分页插件:MyBatis-Plus提供了强大的分页插件,支持多种数据库的分页查询,开发者可以轻松实现分页查询功能。
  4. 代码生成器:MyBatis-Plus内置了代码生成器,可以根据数据库表自动生成Entity、Mapper、Service、Controller等代码,减少了重复的CRUD代码编写工作。
  5. 乐观锁插件:MyBatis-Plus提供了乐观锁的支持,可以通过注解的方式实现乐观锁功能,确保数据的一致性。

SpringBoot集成MyBatis-Plus

第一个MyBatisPlus程序

创建项目,提前引入支持的依赖(热部署、mysql、lombok、Web)

引入依赖

<!--已包含mybatis依赖-->
<dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.3.2</version>
</dependency>
<!-- 引入阿里巴巴连接池-->
<dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId><version>1.1.19</version>
</dependency>

配置文件

mapper文件映射和实体别名,mybatisplus已经配置了,所以不需要再写了。

spring:datasource:type: com.alibaba.druid.pool.DruidDataSourcedriver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://localhost:3306/ems?characterEncoding=UTF-8username: rootpassword: root

包扫描配置、实体类

@Data
public class User {private Long id;private String name;private Integer age;private String email;private Long managerId;private LocalDateTime createTime;
}
@SpringBootApplication
@MapperScan("com.mp.dao")
public class MyBatisPlusLessionApplication {public static void main(String[] args) {SpringApplication.run(MyBatisPlusLessionApplication.class, args);}
}

实现mapper接口

  • 使用**mybatisplus** 的增强接口 BaseMapper

    // BaseMapper的泛型一定要写,否则返回不了数据
    public interface UserMapper extends BaseMapper<User> {}
    

测试

@SpringBootTest
class MyBatisPlusLessionApplicationTests {@Autowiredprivate UserMapper userMapper;@Testpublic void select() {**List<User> list = userMapper.selectList(null);// null指的是没有查询条件**list.forEach(System.out::println);}
}

返回数据成功

以下是BaseMapper中常用的方法:

方法名描述
insert插入一条记录
insertBatch批量插入记录
deleteById根据ID删除记录
deleteByMap根据Map条件删除记录
delete根据条件删除记录
updateById根据ID更新记录
update根据条件更新记录
selectById根据ID查询记录
selectBatchIds根据ID列表批量查询记录
selectByMap根据Map条件查询一条记录
selectOne查询满足条件的一条记录
selectCount查询满足条件的记录数
selectList查询满足条件的记录列表
selectMaps查询满足条件的记录,返回Map列表
selectObjs查询满足条件的记录,返回Object列表
selectPage分页查询记录

基本使用

  • 日志配置

    logging:level:root: warn # 根日志com.mp.dao: trace # 指定包级别pattern:console: '%p%m%n' # 格式
    

Insert

@Test
public void insert() {User user = new User();user.setName("刘东");user.setAge(21);user.setEmail("xiaohei@qq.com");user.setManagerId(1L);user.setCreateTime(LocalDateTime.now());int rows = userMapper.insert(user);System.out.println("影响记录数:"+rows);
}

运行结果,成功插入数据

注意:我们在set中并没有插入id,但是运行结果成功插入了一串id值,因为这是mybatis-plus基于雪花算法实现的自增id。

常用注解 @TableName@TableId@TableFieId

@Data
@TableName("mp_user")
public class User {@TableIdprivate Long userId;@TableField("name")private String realName;private Integer age;private String email;private Long managerId;private LocalDateTime createTime;
}

**@TableName**用于指定实体类对应的数据库表名,如果不指定,就以类名作为映射关系

@TableId 注解来指定主键

@TableFieId 用于标识实体类中的字段与数据库表中的列的映射关系。

排除非表字段的三种方式

  1. transient 【不推荐】

    private transient String remark;
    

    不推荐在MyBatis Plus中使用Java语言中的**transient关键字来排除非表字段的原因是,transient关键字主要用于Java对象的序列化过程,用于标记不需要序列化的字段。但是,对于数据库操作而言,transient**关键字并不会影响字段的持久化行为,因为它只是在Java对象的序列化和反序列化过程中起作用。

  2. static 【不推荐】

    private static String remark;
    
  3. @TableField(exist = false) 【推荐】

    @TableField(exist = false)
    private static String remark;
    

    在进行数据库操作时,MyBatis-Plus会自动排除带有**@TableField(exist = false)**注解的非表字段,不会将它们包含在生成的SQL语句中。

这篇关于Spring Boot学习随笔- 集成MyBatis-Plus,第一个MP程序(环境搭建、@TableName、@TableId、@TableField示例)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/551837

相关文章

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

MyBatis中$与#的区别解析

《MyBatis中$与#的区别解析》文章浏览阅读314次,点赞4次,收藏6次。MyBatis使用#{}作为参数占位符时,会创建预处理语句(PreparedStatement),并将参数值作为预处理语句... 目录一、介绍二、sql注入风险实例一、介绍#(井号):MyBATis使用#{}作为参数占位符时,会

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控