💠

💠 2024-03-26 21:19:24


Mybatis

Official
mybatis-issuesSSCCE: Short, Self Contained, Correct (Compilable), Example.

一个灵活的数据库中间件框架 参考: 如何在MyBatis中优雅的使用枚举

mybatis系统学习

$ 和 # 的区别 =-]

  • ${} 会有SQL注入的漏洞,#{}则没有
    • 使用 $ 是SQL进行String直接进行拼接,使用#是preparstatement的预处理然后注入
  • 都遵循 OGNL 语法

流程控制

foreach 循环语句

1
2
3
    <foreach collection="param_list 自定义的话就是Map中的key,或者使用 @Param("")来指定 " item="params" index="currentIndex 当前索引"  separator="循环分隔符" open="在循环前加上字符" close="循环结束后加上字符">
        ${params}
    </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整合

spring和mybatis整合


Tips

  1. 展示执行SQL logging.level.mapperAbsolutePackagePath=DEBUG Logging
  2. Mybatis-Plus 有个 ActiveRecords 模式,想要让实体具有持久层的能力。整个框架都不利于寻找数据的流入 入口。