1.MyBatis中的延迟加载
开启延迟加载前后的有效区别:
在用的时候去调用另一个文件的方法
2.mybatis中的缓存
当数据库的数据更新和一级缓存不一致时,如何处理的?
----》在查找时,一级缓存已被清空,所以直接从数据库中获取对应的数据
一级缓存失效:
1)在查询之后进行了增删改的操作,则再次进行查询时,需要到数据库中进行查找;
2)当前的sqlSession会话被清空,则查询需要建立新的连接,到数据库中进行查询;
默认数true
当拿出数据时,会创造一个新的对象
3.mybatis注解开发
1)创建项目,导入依赖的包,创建主配置文件mybatis-cfg.xml(包含数据库连接配置、指定注解接口的配置文件等)
2)创建实体类,implements序列化接口
3)创建实体类对应的接口,在里面添加对应的方法(Mapper)在方法上添加注解
@Select、 @Update、@Insert、@Delete
4)编写测试类
**实例分析:
使用注解开发,则不能使用配置文件;
使用注解解决实体属性名和数据库列名不一致情况:id默认为false,指明主键只需要将对应的id设置为true即可
**使得其他的方法可以通过id来使用这个Results
或者直接传入userMap
**注解开发一对一的查询配置:
**注解开发一对多的配置
fetchType使用了延迟加载(一般用在多表查询中),在一个表的操作使用立即加载
**注解开发使用二级缓存(默认是开启的)
(不用考虑以及缓存)
设置二级缓存对应的配置:首先在mybatis-cfg.xml文件中设置对应的配置,然后在接口类的
头部设置CachedNameSpace(blocking = true)即可。