JavaEE简单示例——MyBatis的缓存机制
创始人
2024-05-30 10:30:32
0

简单介绍:

缓存机制的存在,是为了当我们在执行重复的SQL代码的时候,不需要重新向数据库进行访问,而是将之前查询的结果存放在内存当中,从而减少我们重复的获取数据库连接进行查询时候消耗的资源,是一种加快查询速度,优化查询方式的一种方法。

在MyBatis中,缓存机制有两种,一种是默认的一级缓存,另一种是需要我们手动进行配置的二级缓存。一级缓存是SqlSession级别的缓存,当我们在使用同一个SqlSession多次执行相同的SQL查询语句之后,在第一次查询的时候,会将查询结果缓存到内存中。此后,如果程序不进行增删改查的操作,那么当之后多次执行相同的查询语句的时候,都只会从内存中获取数据,并不会连接到数据库。

使用方法:

由于MyBatis默认情况下就是采用的一级缓存,所以我们不需要做任何关于缓存的相关配置。为了方便我们观察SQL语句的执行过程,我们需要条件一个log4j的依赖,并且添加相关的配置文件,这个组件会帮我们把日志打印到控制台,方便我们观察我们SQL语句的执行过程。

pom依赖:

log4jlog4j1.2.17

 log4j的配置文件,这是一个properties文件:此处需要注意,log4j的配置文件的命名必须写作:log4j.properties,这是log4j的使用规范之一


log4j.rootLogger=DEBUG,consolelog4j.appender.console = org.apache.log4j.ConsoleAppender
log4j.appender.console.Target = System.out
log4j.appender.console.Threshold=DEBUG
log4j.appender.console.layout = org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=[%c]-%m%n

代码实现:

在写好配置文件之后,我们就可以进行代码的测试了,我们只需要写一个简单的从用户表查询数据即可:

映射文件:








insert into user values (#{id} , #{name} , #{sex} , null , null);
delete from user where id = #{id};

测试类:

package mappers;import com.mybatis.User;
import junit.framework.TestCase;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;import java.io.InputStream;
import java.util.List;public class selectTest extends TestCase {SqlSession session = null;select mapper = null;public void setUp() throws Exception {InputStream stream = Resources.getResourceAsStream("mybatis.xml");SqlSessionFactory build = new SqlSessionFactoryBuilder().build(stream);session = build.openSession(true);mapper = session.getMapper(select.class);}public void testSelectOne() {System.out.println("第一次查询:");Object o = session.selectOne("mappers.select.selectOne", 1);User u = (User)o;System.out.println(u.toString());System.out.println("第二次查询:");Object o2 = session.selectOne("mappers.select.selectOne", 1);User u2 = (User)o1;System.out.println(u2.toString());}}

在这个案例中,我们使用SqlSession对同一个SQL语句进行了两次查询, 重点在于我们接下来的运行结果在控制台的输出

运行结果:

红色框的内容是我们两次查询的执行过程,其中我们可以看到,蓝色框的SQL语句的查询只在第一次查询的时候出现过,第二次查询的时候并没有任何的关系connection或者SQL语句之类的信息出现,说明这是直接从内存中获取到的上一次查询的缓存,这也就体现了我们MyBatis的一级缓存。 

或者我们可以查询两条不一样的SQL语句来看一下区别:

红色框里面的是两条不一样的SQL语句,SQL语句相同表示两条SQL语句必须是一摸一样,包括查询的参数。然后我们再来看控制台输出的信息:

 这里就可以很明显的看到,第二次SQL语句的查询依然是传递并执行了SQL语句,与上一个演示的案例的区别就很明显了。 

注意点:

MyBatis的一级缓存是默认的,并且一级缓存是针对于SqlSession的缓存,也就是只有当我们使用SqlSession进行查询的时候才能体现出一级缓存的作用,下一章我们会介绍针对于mapper的二级缓存机制。

上一篇:Vue2的基本使用

下一篇:集合 部分笔记

相关内容

热门资讯

手机安卓系统越高越好,探索最新... 你有没有发现,每次手机更新系统,你的手机就像脱胎换骨了一样?没错,说的就是你,那个安卓手机!今天,咱...
鸿蒙系统怎么用回安卓,轻松实现... 你是不是也和我一样,对鸿蒙系统的新鲜感还没过,却又忍不住想回到熟悉的安卓世界?别急,今天就来手把手教...
苹果7跟安卓系统,性能对决与用... 你有没有想过,为什么苹果7那么受欢迎,而安卓系统却有着庞大的用户群体?今天,我们就来聊聊这个话题,看...
安卓手机刷简化系统,轻松实现流... 你有没有想过,你的安卓手机其实可以变得更加轻快、流畅呢?没错,就是通过刷简化系统!今天,就让我带你一...
社保掌上通安卓系统,轻松掌握在... 你有没有发现,现在的生活越来越离不开手机了?无论是购物、聊天还是办公,手机都能轻松搞定。这不,今天就...
安卓系统便宜的手机,盘点安卓系... 你有没有想过,拥有一部安卓系统的手机,却不用花大价钱?现在,我就要给你揭秘那些价格亲民,性能却不打折...
安卓8.0系统单机游戏,探索单... 你有没有发现,自从安卓8.0系统更新后,手机里的游戏体验简直像开了挂一样?没错,今天就来聊聊这个话题...
适合安卓系统平板笔记,高效笔记... 你有没有发现,随着科技的发展,平板电脑已经成为了我们生活中不可或缺的好伙伴呢!尤其是安卓系统的平板,...
旗鱼平板刷安卓系统,畅享智能生... 你有没有想过,你的旗鱼平板刷上安卓系统后,世界会变得多么精彩?想象那些原本只能在电脑上畅游的APP,...
安卓系统更新强行停止,揭秘原因... 最近你的安卓手机是不是也遇到了一个让人头疼的问题?没错,就是安卓系统更新突然强行停止了!这可真是让人...
安卓系统如何备份图片,轻松保存... 手机里的照片可是我们珍贵的回忆啊!有没有想过,万一手机不小心摔了或者丢失了,那些珍贵的瞬间可就找不回...
安卓主流系统哪个好用,探寻最佳... 你有没有想过,手机里的安卓系统就像是我们生活中的各种品牌,各有各的特色和魅力。那么,这么多安卓系统里...
喜欢苹果像素安卓系统,系统之魂 你有没有发现,身边的朋友对手机的选择越来越有个性了呢?有的人偏爱苹果的优雅,有的人则钟情于安卓的活力...
安卓xp系统哪个好用,探寻最佳... 你有没有想过,手机系统就像是我们生活中的各种软件,各有各的特色和优势。今天,咱们就来聊聊安卓系统中的...
安卓系统云端怎么备份,轻松实现... 你有没有想过,手机里的那些珍贵的照片、视频和文件,万一不小心丢失了怎么办?别担心,今天就来给你支个招...
安卓系统9.0与ios,系统革... 你知道吗?在智能手机的世界里,安卓系统和iOS系统就像是一对相爱相杀的“欢喜冤家”。今天,咱们就来聊...
新机安卓怎么激活系统,体验流畅... 你新入手的安卓手机是不是有点儿蒙圈?别急,今天就来手把手教你如何激活系统,让你的新机焕发活力!?一、...
如何删除安卓系统信息,安卓系统... 手机里的信息越来越多,是不是感觉自己的隐私都快要被暴露无遗了?别担心,今天就来教你怎么轻松删除安卓系...
国产安卓系统哪个流畅,揭秘哪家... 你有没有想过,手机里的操作系统就像是我们的大脑,有时候它运行得快慢,直接影响我们的使用体验呢?今天,...
安卓怎么刷主机系统,掌握主机系... 你有没有想过,你的安卓手机或者平板,是不是也能像电脑一样,装上各种酷炫的系统呢?没错,今天就要来给你...