前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mybatis拦截器初探

mybatis拦截器初探

作者头像
蛋蛋编程手记
发布2023-02-25 17:01:52
2540
发布2023-02-25 17:01:52
举报
文章被收录于专栏:蛋蛋编程手记蛋蛋编程手记

最近项目里用到了mybatis的拦截器,然后想到之前面试被问过这个问题,当时没有回答上来,于是就好好的研究了一下。

项目里面是在分页的流程上使用了拦截器,通过配置mybatis拦截器简化了分页代码的编写过程。

我们知道要做一个分页需要有两步sql查询。首先根据条件查询总条数,然后查询分页的结果集合,然后后端将数据组织成一个分页结果对象。前端那边则根据后端返回的分页结果组织页码列表以及当前页数据展示。

常规思路就是在mapper接口中写两个方法,在xml中写两个方法,然后再service中组织最终的结果。

通过mybatis的拦截器,我们省略掉了service的数据组织过程,以及mapper中查询总数方法的定义。

也就是说我们只需要定义一个查询数据的方法,它返回最终的分页对象,以及xml里面查总数和查具体数据集合的sql。至于为什么不把查总数也省略掉,是因为查总数自己手写可以会有一些看得见的优化。

当然这个技术还有很多其他的用法,比如分表分库操作,统计sql执行时间等等,后面有时间蛋蛋会继续分享的。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2023-02-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 蛋蛋编程手记 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档