海风影像馆 海风影像馆
首页
扎根医疗
学习笔记
技术实战
项目管理
影像空间
驴行天下
阳明心学
  • 学习方法
  • 心情杂货
  • 实用技巧
  • 友情链接
  • 分类
  • 标签
  • 归档

知行旅人

生有热烈,藏于俗常。
首页
扎根医疗
学习笔记
技术实战
项目管理
影像空间
驴行天下
阳明心学
  • 学习方法
  • 心情杂货
  • 实用技巧
  • 友情链接
  • 分类
  • 标签
  • 归档
  • 数据结构

  • 算法

  • Java基础

  • Java并发

  • JVM

  • 开发框架

    • SpringMVC
    • Spring
    • Mybatis
      • 1 Mybatis常见问题
        • 1.1 Mybatis是如何进行分页的?分页插件的原理是什么?
        • 1.2 Mybatis有哪些动态sql标签?
        • 1.3 Mybatis Xml映射文件中有哪些常见标签?
        • 1.4 Mybatis的一级、二级缓存
        • 1.5 Mybatis一对一、一对多的关联查询
      • 2 Mybatis插件
        • 2.1 Mybatis插件的运行原理?
        • 2.2 如何编写一个Mybatis插件?
    • Sentinel
    • Spring Security Oauth2
    • SpringBoot
    • Spring Cloud Gateway
  • 持久化

  • 缓存

  • 消息中间件

  • 微服务

  • 系统架构

  • 网络

  • 操作系统

  • 学习笔记
  • 开发框架
zhixinglvren
2022-05-08
目录

Mybatis

# 1 Mybatis常见问题

# 1.1 Mybatis是如何进行分页的?分页插件的原理是什么?

1.Mybatis使用RowBounds对象进行分页,它是针对结果集进行的内存分页。

2.分页插件的原理是使用Mybatis提供的插件接口,实现自定义插件,可以在插件的拦截方法内拦截待执行的sql,然后重写sql来完成物理分页。

# 1.2 Mybatis有哪些动态sql标签?

Mybatis提供了9种动态sql标签:trim、where、set、foreach、if、choose、when、otherwise、bind

# 1.3 Mybatis Xml映射文件中有哪些常见标签?

select、insert、update、delete、resultMap、parameterMap、sql、include,加上动态sql9个标签,其中<sql>为sql片段标签,通过<include>标签引入sql片段。

# 1.4 Mybatis的一级、二级缓存

一级缓存:Mybatis的一级缓存是利用SqlSession实现的,同样的sql,如果在同一个SqlSession执行,就会利用一级缓存,提高查询效率。

二级缓存:存储作用域为Mapper(Namespace),可自定义存储源,如redis。

# 1.5 Mybatis一对一、一对多的关联查询

# 2 Mybatis插件

# 2.1 Mybatis插件的运行原理?

Mybatis使用JDK的动态代理,为指定的接口生成代理对象,实现接口方法拦截功能。Mybatis仅支持4种指定接口的插件,分别是:ParameterHandler、ResultSetHandler、StatementHandler、Executor。

# 2.2 如何编写一个Mybatis插件?

实现Mybatis的Interceptor接口并重写intercept()方法,然后给插件编写注解,指定要拦截哪一个接口的哪些方法即可。另外还需要在配置文件中配置好编写的插件。

#Mybatis
上次更新: 2022/11/24, 17:59:25
Spring
Sentinel

← Spring Sentinel→

最近更新
01
Linux常用指令
11-24
02
GitHub高级搜索技巧
11-24
03
散列表
11-09
更多文章>
Theme by Vdoing | Copyright © 2020-2023 知行旅人 | MIT License | 粤ICP备20036515号-1
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式