首先mybatis是对jdbc的封装之后的框架,它并不直接对接数据库。
缓存
mybatis有一级缓存和二级缓存,一级缓存是sqlsession级别的,二级缓存是mapper(namespace级别的)
mybatis默认是一级缓存
# 和 $的区别
引用: mybatis 的强大特性之一,也是它优于其他 ORM 框架的一个重要原因。mybatis 在对 sql 语句进行预编译之前,会对 sql 进行动态解析,解析为一个 BoundSql 对象,也是在此处对动态 SQL 进行处理的,动态解析流程大致如下:
1、占位符的处理
2、动态sql的处理
3、参数类型校验
$仅仅是String的替换,而#是sql预编译语句参数标识符
resultMap
使用场景一:一般开发会定义与数据库对应model对象和返回前端vo对象,而处理方式有俩种:
- 自己写业务代码将model处理成vo对象
- 利用mybatis里面的resultMap过滤选取有用的字段直接返回对象
使用场景二:
除此之外resultMap还可以进行高级复杂的映射,利用resultMap的内部元素可以进行高级映射,内部元素常用比如有(constructor、association、collections)
利用association可以表示嵌套的一对一的关系
利用collections可以表示嵌套的一对多的关系
利用俩个collections嵌套就能表示多对多的关系了