SpringBoot整合Mybatis,使用通用mapper和PageHelper进行分页

简介: 乐哉码农上节介绍了如何整合Security,这节就说下如何再Springboot下使用持久层框架mybatis和牛人封装的通用mapper与mybatis的整合,直接进入正题吧!1.
乐哉码农

上节介绍了如何整合Security,这节就说下如何再Springboot下使用持久层框架mybatis和牛人封装的通用mapper与mybatis的整合,直接进入正题吧!

1.首先引入我们需要的依赖:

通用mapper
PageHelper
mybatis

2.mybatis的配置

配置myabtis有两种方式,一是通过javaconfig配置还有一种直接使用Springbot的配置文件进行设置:mybatis.mapper-locations=classpath:mapper/**/*.xml,但是我这里使用的是mybatis的注解方式所以连这个都不需要配置,另外还需要配置mapUnderscoreToCamelCase这个属性,这是用来我们做查或者新增的时候,mybatis自动会把我们的实体类按照驼峰格式转为数据库里面的下划线格式,好处就是不要写resultmap了。

3.通用mapper的集成

首先我们需要定义一个我们自己的通用mapper接口继承封装好的两个接口(都在tk里面)

MyMapper.java

接下来我将我们对应的mapper继承这个mapper,使用mapper注解

FrameCodeMapper.java

这里面我只写了一个deletes方法,用来进行批量删除的,但是这个mapper已经具备增删改查的所有功能,其中FrameCode是我们与数据表中对应的实体。既然我们已经有了mapper我们就看如何使用他们了

FrameCodeService.java

我们再service层里面进行了了对mapper的调用,我们可以看出selectByExample,insert,updateByPrimaryKey这些方法我们再mapper中都没有定义,说明我们可以直接使用通用mapper里面的方法,我们不需要写哪些重复的增删改查代码了。对于mapper里面封装的crud方法,我这里值=只着重讲一个查询(模糊查询),也许是使用的最常见的,也是mapper里面使用的最麻烦的一个方法,我这里对他进行了一个简单的封装:

4.原始的mapper里面的模糊查询方法

模糊查询的mapper

可以看出这里需要准备criteria进行创建模糊查询,这里还只是模糊查询一个字段,如果后续增加了字段,还需要不断的再这里添加,是不是很麻烦,而且也不好移植,所以我这里就对他进行了简单的封装,用的是反射,自从知道了反射,好多功能上面都用上了,确实很方便

MapperUtils.java

到这里为止,已经将mybatis的集成和通用mapper的使用介绍完毕,最后再介绍一个插件PageHelper的使用

5.PageHelper的集成与使用

我们再做项目时,避免不了会进行分页,我们会自己进行去下分页语句,mysql会使用limit,sqlserver使用top,oracle使用rownumber实现,会不会觉得很不方便,今天我为给大家介绍一下PageHelper这个插件在Springboot中的使用

首先引入插件的依赖

PageHelper的pom

接着对pagehelper进行配置,这里也有两种方式:我都贴出来

利用springboot的配置文件
使用javaconfig模式进行配置

最后介绍下如何在项目中使用:

        1.先从请求参数中获取到pageCurrent(当前页),pageSize(页面大小),因为我前端用的时bjui框架,所以在后台接收到的是这两个字段。

        2.我们将请求参数 PageHelper.startPage(pageCurrent,pageSize);放到这里面

        3.再查询我们需要的数据,例如这样:List entitys = service.getAll(entity);

        4.最后再将数据封装到PageInfo pageInfo=new PageInfo(entitys);这里,

        pageInfo里面存储了我们想要的数据,total,start,limit,size都在里面,我们只需要去除我们关心的数据就好了,我这里值取出了数据的总记录数pageInfo.getTotal(),总的代码记录如下

分页代码的实现

感谢大家能看到这里,文中讲的不正确的地方,欢迎在下方留言,我会及时修正。

欢迎大家关注我的公众号,会不定时更新技术干货。

相关文章
|
4天前
|
SQL Java 数据库连接
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
MyBatis-Plus是一个MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。本文讲解了最新版MP的使用教程,包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段等核心功能。
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
|
13天前
|
SQL 缓存 Java
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
本文详细介绍了MyBatis的各种常见用法MyBatis多级缓存、逆向工程、分页插件 包括获取参数值和结果的各种情况、自定义映射resultMap、动态SQL
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
|
1月前
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
106 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
|
1月前
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
54 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
|
1月前
|
前端开发 Java Apache
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
本文详细讲解了如何整合Apache Shiro与Spring Boot项目,包括数据库准备、项目配置、实体类、Mapper、Service、Controller的创建和配置,以及Shiro的配置和使用。
295 1
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
|
1月前
|
Java 关系型数据库 MySQL
springboot学习五:springboot整合Mybatis 连接 mysql数据库
这篇文章是关于如何使用Spring Boot整合MyBatis来连接MySQL数据库,并进行基本的增删改查操作的教程。
69 0
springboot学习五:springboot整合Mybatis 连接 mysql数据库
|
1月前
|
SQL Java 数据库连接
mybatis使用二:springboot 整合 mybatis,创建开发环境
这篇文章介绍了如何在SpringBoot项目中整合Mybatis和MybatisGenerator,包括添加依赖、配置数据源、修改启动主类、编写Java代码,以及使用Postman进行接口测试。
17 0
mybatis使用二:springboot 整合 mybatis,创建开发环境
|
1月前
|
Java 数据库连接 API
springBoot:后端解决跨域&Mybatis-Plus&SwaggerUI&代码生成器 (四)
本文介绍了后端解决跨域问题的方法及Mybatis-Plus的配置与使用。首先通过创建`CorsConfig`类并设置相关参数来实现跨域请求处理。接着,详细描述了如何引入Mybatis-Plus插件,包括配置`MybatisPlusConfig`类、定义Mapper接口以及Service层。此外,还展示了如何配置分页查询功能,并引入SwaggerUI进行API文档生成。最后,提供了代码生成器的配置示例,帮助快速生成项目所需的基础代码。
|
1月前
|
Java 数据库连接 Maven
Spring整合Mybatis
Spring整合Mybatis
|
2月前
|
缓存 前端开发 Java
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
Soring Boot的起步依赖、启动流程、自动装配、常用的注解、Spring MVC的执行流程、对MVC的理解、RestFull风格、为什么service层要写接口、MyBatis的缓存机制、$和#有什么区别、resultType和resultMap区别、cookie和session的区别是什么?session的工作原理
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)