1.Mybatis中的延迟加载
问题:在一对多中,当我们有一个用户,它有100个账户
在查询用户的时候,要不要把关联的账户查出来?
在查询账户的时候,要不要把关联的用户查出来?
在查询用户时,用户下的账户信息应该是,什么时候使用,什么时候查询的
在查询账户时,账户的所属用户信息应该是随着账户查询时一起查询出来。
什么是延迟加载?
在真正使用数据时才发起查询,不用的时候不查询。也叫按需加载(懒加载)
什么是立即加载?
不管用不用,只要一调用方法,就马上发起调用。
在对应的四种表关系中:一对多,多对一,一对一,多对多
一对多,多对多:通常情况下我们都采用延迟加载
多对一,一对一:通常情况下我们都采用立即加载
2.Mybatis中的缓存
什么是缓存?
存在于内存中的临时数据
为什么使用缓存
减少和数据库的交互次数,提高执行效率
什么样的数据能使用缓存,什么样的数据不能使用
使用与缓存:
经常查询的并且不经常改变的
数据的正确与否对最终结果影响不大的
不适用于缓存;
经常改变的数据
数据的正确与否对最终结果影响很大
如商品库存,银行汇率
Mybatis中的一级缓存和二级缓存
一级缓存:
它指的是Mybatis中SqlSession对象的缓存当我们执行查询之后,
查询的结果会同时存入到Sqlsession为我们提供的一块区域中,
该区域的结构是一个Map。当我们再次查询同样的数据,mybatis
会先去Sqlsession中查询是否有,有的话直接拿来用。当
Sqlsession对象消失,mybatis的一级缓存也消失
当调用Sqlsession的修改,添加,删除,commit,close等方法,就会删除一级缓存
二级缓存:
它是指Mybatis中SqlsessionFactory对象的缓存。由同一个
SqlsessionFactory对象创建的Sqlsession共享其缓存
二级缓存使用步骤:
第一步:让Mybatis框架支持二级缓存(在Mybatis.xml中设置)
第二部:让当前框架的映射文件支持二级缓存(UserMapper.xml中配置
<cache/>)
第三部:让当前的操作支持二级缓存(在在UserMapper的select标签中
配置userCache="ture" )
3.Mybatis中的注解开发
环境搭建
单表CRUD操作(代理DAO方式)
多表查询方式
缓存的配置
Mybatis的延迟和缓存
最新推荐文章于 2023-10-30 01:44:48 发布