1.一对一关系
例如:
user 用户表 和userCard 身份证表
一个用户只有一个(对应)身份证,同样一个身份证对应一个用户,这就是一对一关系。
xml映射配置文件如下如下:
2.一对多(多对一)关系
例如:
用户 1 ---- 订单 n
一个用户可以会有多个订单,一个订单只能对应一个用户。
用户 1 ---- 账户 n account
一个用户可能会开多个账户,也就是说一个用户会有多个账户。
xml映射配置文件如下:
3.多对多关系
例如:老师 学生
一个老师可能会教多个(对应)学生,一个学生可能也会(对应)有多个老师
用户 角色
一个用户可能会(对应)多个角色,一个角色可能也会(对应)多个用户
xml映射配置文件如下:
二.mybatis的延迟加载
mybatis延迟加载(针对多表查询)
立即加载
查询一个对象的时候,立马的把对象关联的对象查询出来
延迟加载
查询一个对象的时候,关联对象先不查询,什么时候使用对象,什么时候再查询对象
会产生一个n+1的问题
查询用户的时候要查询用户关联的账号
账号信息是什么时候时候,什么时候查询
一对一或者多对一的时候使用 立即加载
一对多 或者多对多查询的时候使用 延迟加载
配置如下:
三.mybatis缓存SELECT * FROM account WHERe uid=#{uid};
1. 一级缓存
特点: 数据是缓存在sqlsession中,通过同一个sqlsession对象去获取数据的时候,第一次从数据库中获取的数据会缓存到sqlsession中,下次再获取相同数据的时候,直接从sqlsession中获取
会话级别的缓存 mybatis的内置缓存
操作数据库的这次会话(对话)
会话级别的缓存,只有在当前这个sqlSession中才会生效。
在同一个SqlSession之间是可以共享缓存的数据的。
一级缓存清空的情况
1. 执行了增删改操作之后 ,一级缓存的数据自动清空
2. 直接关闭sqlSession或者提交事物
3. 手动调用 sqlSession.clearCache();
2. 二级缓存
特点:mybatis的二级缓存数据是缓存在SqlSessionFactory(一个项目只会创建一个SqlSessionFactory对象)
特点:mybatis的二级缓存数据是缓存在SqlSessionFactory(一个项目只会创建一个SqlSessionFactory对象) mapper级别的缓存
每一张数据库表都对应一个mapper,每一张表的数据都缓存在对应的mapper缓存块中,那些缓存但是保存在SqlSessionFactory中
mybatis的二级缓存数据是缓存在SqlSessionFactory
当执行了增删改操作时候,会自动清空当前mapper中的缓存数据。
今日学习感受:既然选择了这条路,义无反顾的坚持下去把!相信,你越努力,它会让你越幸运,你想要的也会随之即来。这就是你付出多少,你就会回报多少,当然有时候你付出也不会有回报,但是IT行业,java后端,只要你肯努力,我敢上一定会有回报,你一定要坚持下去,加油。最后一句话:时间就是金钱!



