首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

mybatis拦截器详解_短信拦截器

拦截器的一个作用就是我们可以拦截某些方法的调用,我们可以选择在这些被拦截的方法执行前后加上某些逻辑,也可以在执行这些被拦截的方法时执行自己的逻辑而不再执行被拦截的方法。Mybatis拦截器设计的一个初衷就是为了供用户在某些时候可以实现自己的逻辑而不必去动Mybatis固有的逻辑。打个比方,对于Executor,Mybatis中有几种实现:BatchExecutor、ReuseExecutor、SimpleExecutor和CachingExecutor。这个时候如果你觉得这几种实现对于Executor接口的query方法都不能满足你的要求,那怎么办呢?是要去改源码吗?当然不。我们可以建立一个Mybatis拦截器用于拦截Executor接口的query方法,在拦截之后实现自己的query方法逻辑,之后可以选择是否继续执行原来的query方法。

02

Mybatis分页查询[通俗易懂]

分页查询作为数据库交互最常用的几种操作之一,在日常开发中是非常常见的,比如前段请求需要一个分页的列表,往往有两种方式,一是把所有的数据都给到前段,前段分页。另外一种方式是前端通过传分页信息给后端,后端查询时进行分页,并将相应页的数据返给前端。第一种方式如果数据规模比较小的情况下可以使用,如果数据量较大,对内存、网络传输的消耗都是非常大的,所以实际开发中一般很少使用。第二种方式是后端进行分页,后端分页的实现又可以分为逻辑分页和物理分页,逻辑分页就是在进行数据库查询时一次性将数据查出来,然后将相应页的数据挑出返回,物理分页就是通过在查询时就查询相应的页的数据(比如直接在mysql查询语句添加limit)。很明显逻辑分页跟第一种前端分页的方式有着相同的弊端。

02

MyBatis Plus 初体验

在平时使用 Mybatis 的时候,总会开发一些通用的增删改查,真正自己定义的方法并不多,这时我们就在考虑:有没有那么一种框架,可以提供简单的 CRUD,还能进行自定义扩展自己的数据库操作层接口,灵活的进行多表联结查询?JPA 标准(实现框架有 Hibernate 和 Spring Data)可以解决上述需求,不过多表联结查询还是不够优雅,个人感觉扩展和自定义查询不够灵活。这个时候一般选用 Myabtis 作为 ORM 框架。只要你用过 Mybatis,就会被它的灵活和简洁征服,但是它没有提供一个通用的 CRUD,Mybatis 的代码生成插件可以生成通用的 CRUD,不过配置稍显麻烦。Myabtis Plus 优雅的解决了上面的问题,对 Myabtis 框架无侵入,也有一个代码生成器,不过本次不作为讨论内容。既然 Mybatis Plus 可以解决上面的问题,一起来看一下。

03
领券