[11-01]mybatis



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的


一般不使用












猜你喜欢

转载自blog.csdn.net/a102615350/article/details/78037914