springboot快速集成mybatis-plus的详细教程

 更新时间:2020年09月08日 11:37:52   作者:子_轩  
这篇文章主要介绍了springboot快速集成mybatis-plus的教程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

简介
Mybatis-Plus(简称MP)是一个 Mybatis 的增强工具,在 Mybatis 的基础上只做增强不做改变,为简化开发、提高效率而生。这是官方给的定义,关于mybatis-plus的更多介绍及特性,可以参考mybatis-plus官网。那么它是怎么增强的呢?其实就是它已经封装好了一些crud方法,我们不需要再写xml了,直接调用这些方法就行,就类似于JPA。

springBoot快速集成mybatis-plus

一、pom文件引入mybatis-plus依赖

 <dependencies>
  <!--web-->
  <dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-web</artifactId>
  </dependency>
  <!--lombok-->
  <dependency>
   <groupId>org.projectlombok</groupId>
   <artifactId>lombok</artifactId>
   <optional>true</optional>
  </dependency>
  <!--mysql驱动-->
  <dependency>
   <groupId>mysql</groupId>
   <artifactId>mysql-connector-java</artifactId>
   <version>5.1.25</version>
  </dependency>
  <!--mybatis-plus-->
  <dependency>
   <groupId>com.baomidou</groupId>
   <artifactId>mybatis-plus-boot-starter</artifactId>
   <version>3.1.0</version>
  </dependency>
  <!---test-->
  <dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-test</artifactId>
   <scope>test</scope>
  </dependency>
 </dependencies>

注: 这里最主要的是mybatis-plus-boot-starter依赖,其他依赖都是基本的

二、基础配置 application.properties

#mysql数据库
spring.datasource.url= jdbc:mysql://127.0.0.1:3306/springbootdemo?characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=GMT%2B8
spring.datasource.username= root
spring.datasource.password= 111111
spring.datasource.driver-class-name=com.mysql.jdbc.Driver

#mybatis
#开启驼峰
mybatis.configuration.map-underscore-to-camel-case=true
#打印日志
mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

#mybatis-plus配置
mybatis-plus.mapper-locations=classpath*:/mappers/*.xml
#主键类型 0:"数据库ID自增", 1:"用户输入ID",2:"全局唯一ID (数字类型唯一ID)", 3:"全局唯一ID UUID";
mybatis-plus.global-config.id-type=0
#字段策略 0:"忽略判断",1:"非 NULL 判断"),2:"非空判断"
mybatis-plus.global-config.field-strategy= 1
#驼峰下划线转换
mybatis-plus.global-config.db-column-underline=true

三、MybatisPlusConfig

/**
 * MybatisPlus配置类
 */
@EnableTransactionManagement
@Configuration
@MapperScan(basePackages = "com.example.demo.mapper")
public class MybatisPlusConfig {

 /**
  * 分页插件
  */
 @Bean
 public PaginationInterceptor paginationInterceptor() {
  return new PaginationInterceptor();
 }
}

四、测试

实体类 主键使用@TableId(value = "id",type = IdType.AUTO)指定类型
@TableField(exist = false):表示该属性不为数据库表字段,但又是必须使用的。

@Data
public class SysUser implements Serializable {
 private static final long serialVersionUID = 1L;
 /**
  * 主键
  */
 @TableId(value = "id",type = IdType.AUTO)
 private Integer id;
 /**
  * 用户名
  */
 private String username;
 /**
  * 密码
  */
 private String password;
 /**
  * 电话
  */
 private String phone;
 /**
  * 邮箱
  */
 private String email;
 /**
  * 创建时间
  */
 private Date createDate;
 /**
  * 更新时间
  */
 private Date updateDate;
 /**
  * sys_user
  */
}

新建SysUserMapper继承 BaseMapper

public interface SysUserMapper extends BaseMapper<SysUser> {
}

测试

@Autowired
 private SysUserMapper sysUserMapper;

 /**
  * 插入
  */
 @Test
 public void insert() {
  SysUser sysUser=new SysUser();
  sysUser.setPhone("18787878787");
  sysUser.setPassword("123456");
  sysUser.setUsername("root");
  sysUser.setCreateDate(new Date());
  sysUser.setUpdateDate(new Date());
  sysUserMapper.insert(sysUser);
 }

 /**
  * 分页查询
  */
 @Test
 public void selectByPage() {
  Page<SysUser> page=new Page(1,1);
  IPage p= sysUserMapper.selectPage(page,new QueryWrapper<SysUser>().eq("password","123456"));
  System.out.println(p.getRecords());
 }

分页一般使用

List<ApiLogVO> getCallLogList(ApiLogDTO dto, Page page); mapper
IPage<ApiLogVO> getCallLogList(ApiLogDTO dto); IService
serviceImpl
	@Override
 public IPage<ApiLogVO> getCallLogList(ApiLogDTO dto) {
  Page<ApiLogVO> page=new Page(dto.getCurrent(),dto.getSize());
  List<ApiLogVO>list= apiLogMapper.getCallLogList(dto,page);
  page.setRecords(list);
  return page;
 } 
 controller
 @PostMapping("/call/log")
 @ApiOperation("api调用日志列表")
 public IPage<ApiLogVO> callLog(@ModelAttribute ApiLogDTO dto){
  return sysService.getCallLogList(dto);
 }

附上目录结构

在这里插入图片描述

总结

到此这篇关于springboot快速集成mybatis-plus的详细教程的文章就介绍到这了,更多相关springboot集成mybatis-plus内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java构造器使用方法及注意事项

    Java构造器使用方法及注意事项

    这篇文章主要介绍了Java构造器使用方法及注意事项的相关资料,这里举例说明如何使用构造器及需要注意的地方,需要的朋友可以参考下
    2017-07-07
  • Spring中的EventListenerMethodProcessor组件详解

    Spring中的EventListenerMethodProcessor组件详解

    这篇文章主要介绍了Spring中的EventListenerMethodProcessor组件详解,EventListenerMethodProcessor 是 Spring 事件机制中非常重要的一个组件,它管理了一组EventListenerFactory组件,用来将应用中每个使用@EventListener注解定义的事件监听,需要的朋友可以参考下
    2023-12-12
  • 如何基于mybatis框架查询数据库表数据并打印

    如何基于mybatis框架查询数据库表数据并打印

    这篇文章主要介绍了如何基于mybatis框架查询数据库表数据并打印,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-11-11
  • Spring系列之事物管理

    Spring系列之事物管理

    这篇文章主要介绍了Spring系列之事物管理,文中通过示例代码介绍的非常详细,对大家学习或者使用spring方面知识具有一定的参考学习价值,需要的朋友们一起学习学习吧
    2021-09-09
  • 一文带你了解Java万物之基之Object类

    一文带你了解Java万物之基之Object类

    Java是一门天然的面向对象的语言。而所有我们手动创造出来的类,都继承于同一个类,即Object类。本文将通过示例为大家详细介绍一下Java中的Object类,需要的可以参考一下
    2022-03-03
  • Java线程之程安全与不安全代码示例

    Java线程之程安全与不安全代码示例

    这篇文章主要介绍了Java线程之程安全与不安全代码示例,还是比较不错的,这里分享给大家,供需要的朋友参考。
    2017-11-11
  • mybatis中${}和#{}的区别以及底层原理分析

    mybatis中${}和#{}的区别以及底层原理分析

    这篇文章主要介绍了mybatis中${}和#{}的区别以及底层原理,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-05-05
  • java实现简单快递系统

    java实现简单快递系统

    这篇文章主要为大家详细介绍了java实现简单快递系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • Java的string类为什么是不可变的

    Java的string类为什么是不可变的

    这篇文章主要介绍了Java的string类为什么是不可变的,总结了三个答案,需要的朋友可以参考下
    2014-04-04
  • Java面试之限流的实现方式小结

    Java面试之限流的实现方式小结

    限流是指在各种应用场景中,通过技术和策略手段对数据流量、请求频率或资源消耗进行有计划的限制,本文为大家整理了常见的限流的实现方式,有需要的可以参考下
    2024-02-02

最新评论