情景引入:
我们在用执行数据库查询操作时,要连接数据库,再去查询,每次都去连接数据库很耗资源。
缓存就是把经常查询的数据放在缓存中,用户去查询的时候再不用再去连接数据库查询了。
1、什么是缓存 [ Cache ]?
-
存在内存中的临时数据。
-
将用户经常查询的数据放在缓存(内存)中,用户去查询数据就不用从磁盘上(关系型数据库数据文件)查询,从缓存中查询,从而提高查询效率,解决了高并发系统的性能问题。
2、为什么使用缓存?
-
减少和数据库的交互次数,减少系统开销,提高系统效率。
-
读写分离,主从复制
3、什么样的数据能使用缓存?
-
经常查询并且不经常改变的数据。
思考:缓存和MySQL的读写分离,主从复制有什么关系?
Mybatis缓存
-
MyBatis包含一个非常强大的查询缓存特性,它可以非常方便地定制和配置缓存。缓存可以极大的提升查询效率。
-
MyBatis系统中默认定义了两级缓存:一级缓存和二级缓存
-
默认情况下,只有一级缓存开启。(SqlSession级别的缓存,也称为本地缓存)
-
二级缓存需要手动开启和配置,他是基于namespace级别的缓存。
-
为了提高扩展性,MyBatis定义了缓存接口Cache。我们可以通过实现Cache接口来自定义二级缓存
-
官方文档
学完Mybatis的个人思考:
学框架的一切最终目的都是为了解耦。
JDBC最大的问题就是高耦合。
jdbc的缺点就是将sql语句融入了原生的service层逻辑语句,不能实现解耦,不利于拓展和重用,mybatis则是一个半orm式的框架,既可以做到解耦,也可以通过xml文件中编写映射关系去处理一些复杂的sql。而且mybatis还内置了缓存,动态sql等强大的功能,省去了自己编写这些代码的时间。
Mybatis可以和Spring容器完美结合。