ToB企服应用市场:ToB评测及商务社交产业平台

标题: Spring Boot学习随笔- 集成MyBatis-Plus(一),第一个MP程序(环境搭建、@T [打印本页]

作者: 八卦阵    时间: 2024-3-11 08:01
标题: Spring Boot学习随笔- 集成MyBatis-Plus(一),第一个MP程序(环境搭建、@T
学习视频:【编程不良人】Mybatis-Plus整合SpringBoot实战教程,提高的你开发效率,后端人员必备!
引言

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

第一个MyBatisPlus程序

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

引入依赖
  1. <dependency>
  2.     <groupId>com.baomidou</groupId>
  3.     <artifactId>mybatis-plus-boot-starter</artifactId>
  4.     <version>3.3.2</version>
  5. </dependency>
  6. <dependency>
  7.     <groupId>com.alibaba</groupId>
  8.     <artifactId>druid</artifactId>
  9.     <version>1.1.19</version>
  10. </dependency>
复制代码
配置文件

mapper文件映射和实体别名,mybatisplus已经配置了,所以不需要再写了。
  1. spring:
  2.   datasource:
  3.     type: com.alibaba.druid.pool.DruidDataSource
  4.     driver-class-name: com.mysql.cj.jdbc.Driver
  5.     url: jdbc:mysql://localhost:3306/ems?characterEncoding=UTF-8
  6.     username: root
  7.     password: root
复制代码
包扫描配置、实体类
  1. @Data
  2. public class User {
  3.     private Long id;
  4.     private String name;
  5.     private Integer age;
  6.     private String email;
  7.     private Long managerId;
  8.     private LocalDateTime createTime;
  9. }
复制代码
  1. @SpringBootApplication
  2. @MapperScan("com.mp.dao")
  3. public class MyBatisPlusLessionApplication {
  4.     public static void main(String[] args) {
  5.         SpringApplication.run(MyBatisPlusLessionApplication.class, args);
  6.     }
  7. }
复制代码
实现mapper接口

测试
  1. @SpringBootTest
  2. class MyBatisPlusLessionApplicationTests {
  3.     @Autowired
  4.     private UserMapper userMapper;
  5.     @Test
  6.     public void select() {
  7.         **List<User> list = userMapper.selectList(null);// null指的是没有查询条件**
  8.         list.forEach(System.out::println);
  9.     }
  10. }
复制代码
返回数据成功

以下是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分页查询记录基本使用

Insert
  1. @Test
  2. public void insert() {
  3.     User user = new User();
  4.     user.setName("刘东");
  5.     user.setAge(21);
  6.     user.setEmail("xiaohei@qq.com");
  7.     user.setManagerId(1L);
  8.     user.setCreateTime(LocalDateTime.now());
  9.     int rows = userMapper.insert(user);
  10.     System.out.println("影响记录数:"+rows);
  11. }
复制代码
运行结果,成功插入数据

注意:我们在set中并没有插入id,但是运行结果成功插入了一串id值,因为这是mybatis-plus基于雪花算法实现的自增id。
常用注解 @TableName、@TableId、@TableFieId
  1. @Data
  2. @TableName("mp_user")
  3. public class User {
  4.     @TableId
  5.     private Long userId;
  6.     @TableField("name")
  7.     private String realName;
  8.     private Integer age;
  9.     private String email;
  10.     private Long managerId;
  11.     private LocalDateTime createTime;
  12. }
复制代码
@TableName用于指定实体类对应的数据库表名,如果不指定,就以类名作为映射关系
@TableId 注解来指定主键
@TableFieId 用于标识实体类中的字段与数据库表中的列的映射关系。
排除非表字段的三种方式

下一章:Spring Boot学习随笔- 集成MyBatis-Plus(二)条件查询QueryWrapper、聚合函数的使用、Lambda条件查询

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4