Mybatis
Contents
💠
-
- 1.1. 流程控制
- 1.1.1. foreach 循环语句
- 1.1.1.1. collection
- 1.1.2. if 判断语句
- 1.1.3. choose 相当于switch语句
- 1.1.1. foreach 循环语句
- 1.2. 延迟加载
- 1.3. 缓存
- 1.3.1. 分布式缓存
- 1.4. Spring整合
- 1.1. 流程控制
💠 2024-03-26 21:19:24
Mybatis
Official
mybatis-issuesSSCCE: Short, Self Contained, Correct (Compilable), Example.
一个灵活的数据库中间件框架 参考: 如何在MyBatis中优雅的使用枚举
$ 和 # 的区别 =-]
${}
会有SQL注入的漏洞,#{}
则没有- 使用 $ 是SQL进行String直接进行拼接,使用#是preparstatement的预处理然后注入
- 都遵循 OGNL 语法
流程控制
foreach 循环语句
|
|
collection
有 arry list map 几种 还有item是必写,其他的是可选的
if 判断语句
-
<if test=""></if>
-
update 判空 set
<set><if test="col!=null">col=#{col},</if></set>
- mybatis会自动去除多余的逗号
choose 相当于switch语句
<choose><when test=""></when></choose>
延迟加载
需要使用到数据的时候才去查询和加载,没有使用到就不加载。 例如A对象有个属性是List<B>
因为A对B是一对多,使用延迟加载就可以达到不使用A属性的B集合对象时不查询B表,使用到才触发查询
缓存
- 一级缓存
- 一级缓存是SqlSession级别的缓存。在操作数据库时需要构造sqlSession对象,在对象中有一个数据结构(HashMap)用于存储缓存数据。不同的sqlSession之间的缓存数据区域(HashMap)是互相不影响的。
- 二级缓存
- 二级缓存是mapper级别的缓存,多个SqlSession去操作同一个Mapper的sql语句,多个SqlSession可以共用二级缓存,二级缓存是跨SqlSession的。
分布式缓存
mybatis提供了一个cache接口,可用于实现自己的缓存逻辑
整合ehcache
其中使用ehcache是本地单机模式的,实际上ehcache是支持分布式的
Spring整合
Tips
- 展示执行SQL
logging.level.mapperAbsolutePackagePath=DEBUG
Logging - Mybatis-Plus 有个 ActiveRecords 模式,想要让实体具有持久层的能力。整个框架都不利于寻找数据的流入 入口。
Author Kuangcp
LastMod 2018-11-21