Mybatis - Kuangcp/Note GitHub Wiki
目录 start
目录 end|2020-05-17 16:13|
一个灵活的数据库中间件框架 参考: 如何在MyBatis中优雅的使用枚举
$ 和 # 的区别 =-]
-
${}
会有SQL注入的漏洞,#{}
则没有- 使用 $ 是SQL进行String直接进行拼接,使用#是preparstatement的预处理然后注入
- 都遵循 OGNL 语法
<foreach collection="param_list 自定义的话就是Map中的key,或者使用 @Param("")来指定 " item="params" index="currentIndex 当前索引" separator="循环分隔符" open="在循环前加上字符" close="循环结束后加上字符">
${params}
</foreach>
有 arry list map 几种 还有item是必写,其他的是可选的
-
<if test=""></if>
-
update 判空 set
<set><if test="col!=null">col=#{col},</if></set>
- mybatis会自动去除多余的逗号
<choose><when test=""></when></choose>
- [ ]
- 一级缓存
- 一级缓存是SqlSession级别的缓存。在操作数据库时需要构造sqlSession对象,在对象中有一个数据结构(HashMap)用于存储缓存数据。不同的sqlSession之间的缓存数据区域(HashMap)是互相不影响的。
- 二级缓存
- 二级缓存是mapper级别的缓存,多个SqlSession去操作同一个Mapper的sql语句,多个SqlSession可以共用二级缓存,二级缓存是跨SqlSession的。
mybatis提供了一个cache接口,可用于实现自己的缓存逻辑
整合ehcache
其中使用ehcache是本地单机模式的,实际上ehcache是支持分布式的
- 展示执行SQL
logging.level.mapperAbsolutePackagePath=DEBUG
Logging