mybatis拦截器与分页插件实例教程

 更新时间:2019年04月04日 09:16:42   作者:五头牛  
Mybatis拦截器常常会被用来进行分页处理。所以下面这篇文章主要给大家介绍了关于mybatis拦截器与分页插件的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用mybatis具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧

mybatis介绍

拦截器的一个作用就是我们可以拦截某些方法的调用,我们可以选择在这些被拦截的方法执行前后加上某些逻辑,也可以在执行这些被拦截的方法时执行自己的逻辑而不再执行被拦截的方法。

MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生类型、接口和 Java 的 POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。

mybatis架构图

我们这个demo实现就是基于mybatis的插件模块(主要实现mybatis的Interceptor接口)

Interceptor接口

package org.apache.ibatis.plugin;

import java.util.Properties;

/**
 * @author Clinton Begin
 */
public interface Interceptor {

 Object intercept(Invocation invocation) throws Throwable;

 Object plugin(Object target);

 void setProperties(Properties properties);
}

demo实现

主要技术 spring boot + mybatis

pom.xml

<dependency>
 <groupId>org.mybatis.spring.boot</groupId>
 <artifactId>mybatis-spring-boot-starter</artifactId>
 <version>1.3.2</version>
</dependency>
<dependency>
 <groupId>mysql</groupId>
 <artifactId>mysql-connector-java</artifactId>
 <scope>runtime</scope>
 </dependency>

数据库 DDL

create table user
(
 id int  auto_increment primary key,
 username varchar(20) null
);

核心代码

 @Override
 public Object intercept(Invocation invocation) throws Throwable {
 logger.info("进入拦截器");
 Object[] args = invocation.getArgs();
 MappedStatement mappedStatement = (MappedStatement) args[0];

 //获取参数
 Object param = invocation.getArgs()[1];
 BoundSql boundSql = mappedStatement.getBoundSql(param);
 Object parameterObject = boundSql.getParameterObject();

 /**
  * 判断是否是继承PageVo来判断是否需要进行分页
  */
 if (parameterObject instanceof PageVo) {
  //强转 为了拿到分页数据
  PageVo pagevo = (PageVo) param;
  String sql = boundSql.getSql();
  
  //获取相关配置
  Configuration config = mappedStatement.getConfiguration();
  Connection connection = config.getEnvironment().getDataSource().getConnection();

  //拼接查询当前条件的sql的总条数
  String countSql = "select count(*) from (" + sql + ") a";
  PreparedStatement preparedStatement = connection.prepareStatement(countSql);
  BoundSql countBoundSql = new BoundSql(config, countSql, boundSql.getParameterMappings(), boundSql.getParameterObject());
  ParameterHandler parameterHandler = new DefaultParameterHandler(mappedStatement, parameterObject, countBoundSql);
  parameterHandler.setParameters(preparedStatement);
  //执行获得总条数
  ResultSet rs = preparedStatement.executeQuery();
  int count = 0;
  if (rs.next()) {
  count = rs.getInt(1);
  }
  //拼接分页sql
  String pageSql = sql + " limit " + pagevo.getLimit() + " , " + pagevo.getOffset();
  //重新执行新的sql
  doNewSql(invocation, pageSql);

  Object result = invocation.proceed();
  connection.close();
  //处理新的结构
  PageResult<?> pageResult = new PageResult<List>(pagevo.page, pagevo.rows, count, (List) result);
  List<PageResult> returnResultList = new ArrayList<>();
  returnResultList.add(pageResult);

  return returnResultList;
 }
 return invocation.proceed();
 }

测试结果

github地址:https://github.com/XINYANJIANG/mybaits-plugs (本地下载

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。

相关文章

  • 教你使用Java实现扫雷小游戏(最新完整版)

    教你使用Java实现扫雷小游戏(最新完整版)

    本文给大家介绍使用Java实现扫雷小游戏,本程序封装了五个类,分别是主类GameWin类,绘制底层地图和绘制顶层地图的类MapBottom类和MapTop类,绘制底层数字的类BottomNum类,以及初始化地雷的BottomRay类和工具GameUtil类,用于存静态参数和方法,感兴趣的朋友一起看看吧
    2022-05-05
  • java多线程的同步方法实例代码

    java多线程的同步方法实例代码

    这篇文章主要介绍了 java多线程的同步方法实例代码的相关资料,需要的朋友可以参考下
    2017-04-04
  • Java程序执行cmd命令全过程

    Java程序执行cmd命令全过程

    这篇文章主要介绍了Java程序执行cmd命令全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • idea 2023.1字体设置及自动调整大小的图文教程

    idea 2023.1字体设置及自动调整大小的图文教程

    这篇文章主要介绍了idea 2023.1字体设置及自动调整大小的教程,本文通过图文并茂的形式给大家介绍的非常详细,需要的朋友可以参考下
    2023-07-07
  • 一文理解kafka rebalance负载均衡

    一文理解kafka rebalance负载均衡

    这篇文章主要为大家介绍了kafka rebalance负载均衡的深入理解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • Java数据类型的全面剖析

    Java数据类型的全面剖析

    这篇文章主要介绍了Java基本数据类型,结合实例形式详细分析了java基本数据类型、数据类型范围、易错题等相关原理与操作技巧,需要的朋友可以参考下
    2021-10-10
  • Java上传视频实例代码

    Java上传视频实例代码

    本文通过实例代码给大家讲解了java上传视频功能,代码分为页面前台和后台,工具类,具体实例代码大家通过本文学习吧
    2018-01-01
  • tk.Mybatis 插入数据获取Id问题

    tk.Mybatis 插入数据获取Id问题

    本文主要介绍了tk.Mybatis 插入数据获取Id问题,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-12-12
  • MyBatis入门介绍(超简单)

    MyBatis入门介绍(超简单)

    mybatis是Java的持久层框架, JAVA操作数据库是通过jdbc来操作的,而mybatis是对jdbc的封装。下文给大家介绍mybatis入门知识,感兴趣的朋友参考下吧
    2017-08-08
  • Java反射之通过反射获取一个对象的方法信息(实例代码)

    Java反射之通过反射获取一个对象的方法信息(实例代码)

    下面小编就为大家带来一篇Java反射之通过反射获取一个对象的方法信息(实例代码)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-10-10

最新评论