博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mybatis拦截器,分页插件
阅读量:4695 次
发布时间:2019-06-09

本文共 1741 字,大约阅读时间需要 5 分钟。

mybatis拦截器,也就是插件。

在之前学习javaweb时,有filter过滤器,mybatis的拦截器与之很相似。

mybatis的拦截器在映射语句执行过程中进行拦截,而且只能拦截四大对象中的方法。

1.Executor 执行器对象

2.ParameterHander 参数处理器对象

3.ResultSetHander 结果集处理器对象

4.StatementHander 构建sql语句处理器对象

使用拦截器的步骤

1.创建类实现Interceptorj接口,设置@Intercepts,重写接口中的方法

@Intercepts({@Signature(        type = Executor.class,//对象类型,只能是四大对象类型        method = "update", //拦截方法        args ={MappedStatement.class,Object.class/*方法中用到的参数类型*/})})//可以点击拦截对象查看拦截方法的参数,public class PageIntercepts implements Interceptor {//    拦截方法,返回结果:目标方法执行后返回的结果    @Override    public Object intercept(Invocation invocation) throws Throwable {        return invocation.proceed();    }//    获取配置文件中的参数信息,该方法可以不重写    @Override    public void setProperties(Properties properties) {    }}

2.注册插件

至此一个拦截器就完成了。

下面我们自己写一个基于拦截器的分页插件,通过改造上面的模板:

@Intercepts({@Signature(        type = StatementHandler.class,//对象类型,只能是四大对象类型        method = "prepare", //拦截方法        args ={Connection.class,Integer.class/*方法中用到的参数类型*/})})//可以点击拦截对象查看拦截方法的参数,public class PageIntercepts implements Interceptor {//    拦截方法,返回结果:目标方法执行后返回的结果    @Override    public Object intercept(Invocation invocation) throws Throwable {        //获取目标对象        StatementHandler statementHandler = (StatementHandler) invocation.getTarget();//        获取要执行的sql命令        String sql = statementHandler.getBoundSql().getSql();        System.out.println("要执行的sql命令为:"+sql);//        为sql语句添加分页        sql+=" limit 0,10";//        元数据对象,可以对原始数据进行操作        MetaObject metaObject = SystemMetaObject.forObject(statementHandler);//        重新绑定修改后的sql语句        metaObject.setValue("boundSql.sql", sql);//        执行目标方法        return invocation.proceed();    }

在配置文件注册该拦截器后,进行测试

 

转载于:https://www.cnblogs.com/Zs-book1/p/11279345.html

你可能感兴趣的文章
php提示undefined index的几种解决方法
查看>>
LRJ
查看>>
Struts2环境搭建
查看>>
Linux: Check version info
查看>>
stl学习之测试stlen,cout等的运行速度
查看>>
魔戒三曲,黑暗散去;人皇加冕,光明归来
查看>>
Error和Exception
查看>>
Python和Singleton (单件)模式[转载]
查看>>
httpclient设置proxy与proxyselector
查看>>
IT常用单词
查看>>
拓扑排序
查看>>
NYOJ--32--SEARCH--组合数
查看>>
JMS
查看>>
gulpfile 压缩模板
查看>>
【34.14%】【BZOJ 3110】 [Zjoi2013]K大数查询
查看>>
【 henuacm2016级暑期训练-动态规划专题 A 】Cards
查看>>
第五篇:白话tornado源码之褪去模板的外衣
查看>>
设备常用框架framework
查看>>
bootstrap模态框和select2合用时input无法获取焦点(转)
查看>>
21世纪经济网APP
查看>>