1.1mybatis整体架构
1.2 解决字段名和属性名不一致的问题
1.在sql语句中给字段取别名
2.配置文件中开启驼峰映射
3.resultmap解决
1.3 动态代理mapper的实现类
命名空间Namespace定义本身没有限制,只要不重复就行。
但是如果想用mybatis提供的dao动态代理,namespace必须为dao接口全路径
1.4 mybatis插件plugins(又名拦截器)
mybatis插件使用非常简单,只需实现interceptor接口,并指定想要拦截的方法签名即可
1.5 #{}与${}的区别
#{} 是占位符,会预编译,能够防止sql注入
${} 用于sql拼接,不会预编译,不能防止sql注入
有些情况必须用${},不能预编译,比如分表的时候
查询哪张表不确定,表名是动态的。
1.6 ResultMap
resultMap可以解决两个问题
1.pojo属性名和表结构字段名不一致的问题
2.完成高级查询,比如,一对一,一对多,多对多
二,缓存
2.1 一级缓存
同一个session,相同的sql和参数,会命中缓存,一级缓存默认开启,并且无法关闭
在执行insert,update,delete会刷新缓存
2.2二级缓存
作用域是一个mapper的namespace,同一个namespace中查询sql可以从缓存中命中
二级缓存是可以跨session的
一般不使用