- mybatis分页:逻辑分页:指使用RowBounds进行分页,指一次性查询多条数据,然后再这些数据中查找数据;物理分页:手动写sql分页或使用分页插件pageHelper,去数据库查询指定条数的分页数据
- roubounds:rowbouns表面上查询所有数据,其实并非一次查询所有数据,因为mybatis是对jsbc的封装,再jsbc内部含有fetch size配置,它规定了每次从数据库查询多少条数据,如果要查询更多数据,它会在执行next()的时候,去查询更多的数据,可以有效放置内存溢出。
- mybatis支持延迟加载,lazyloadingenable = true即可。原理是再调用时触发,如a.getB().getName(),会先调用getB()发现为null,这个sql查询数据然后再调用sql去查询数据
- mybatis缓存机制:mybatis都是基于perpetualCache的hashMap本地缓存。区别:一级缓存声明周期和SQLSession是一致的,如果有多个SQLSession或者分布式环境中数据库操作,可能会出现脏数据,当session flush或者close之后,该session种所有cache将清空,默认一级缓存式开启的;二级缓存存储域为mapper级别的,如果多个SQLSession之间需要共享缓存,则需要升级到二级缓存,二级缓存可以自定义资源,如ehcache。程序默认不打开二级缓存,如果要开启二级缓存则需要相关的类实现serializable序列化接口。
- 开启二级缓存数据查询流程:二级缓存 -> 一级缓存 -> 数据库;缓存更新机制;当某一个作用域进行操作操作后默认该作用域下所有sl
java学习总结(四)
最新推荐文章于 2024-04-09 00:00:54 发布