【MyBatis】篇四.MyBatis缓存和逆向工程
创始人
2024-06-02 10:24:21
0

= = = =MyBatis整理= = = =

篇一.MyBatis环境搭建与增删改查
篇二.MyBatis查询与特殊SQL
篇三.自定义映射resultMap和动态SQL
篇四.MyBatis缓存和逆向工程

文章目录

  • 1、MyBatis缓存
    • 1.1 MyBatis的一级缓存
    • 1.2 MyBatis的二级缓存
    • 1.3 MyBatis缓存查询的顺序
    • 1.4 整合第三方缓存EHCache
  • 2、MyBatis的逆向工程
    • 2.1 创建MyBatis逆向工程的步骤:
    • 2.2 方法使用说明
  • 3.MyBatis分页插件
    • 3.1 分页插件的配置步骤
    • 3.2 分页插件的使用

1、MyBatis缓存

缓存,即将当前查询出来的数据做一个记录,等下一次查询相同数据的时候,直接在缓存中拿数据,而不用重新去数据库。

1.1 MyBatis的一级缓存

一级缓存是SqlSession级别的,通过同一个SqlSession查询的数据会被缓存,下次查询相同的数据,就会从缓存中直接获取,不会从数据库重新访问

一级缓存失效的四种情况:

  • 不同的SqlSession对应不同的一级缓存
  • 同一个SqlSession但是查询条件不同
  • 同一个SqlSession两次查询期间执行了任何一次增删改操作(以防影响查询结果的正确性)
  • 同一个SqlSession两次查询期间手动清空了缓存

在这里插入图片描述
不同的sqlSession,缓存失效,两次查询,执行两次SQL:

在这里插入图片描述

调用sqlSession对象的clearCache()方法,缓存被清空,执行两次SQL:
在这里插入图片描述

1.2 MyBatis的二级缓存

二级缓存是SqlSessionFactory级别,通过同一个SqlSessionFactory创建的SqlSession查询的结果会被缓存。此后若再次执行相同的查询语句,结果就会从缓存中获取。
在这里插入图片描述

二级缓存开启的条件:

  • 在核心配置文件中,设置setting全局配置属性cacheEnabled=“true”,默认为true,不需要设置
  • 在映射文件中设置标签
  • 二级缓存必须在SqlSession关闭或提交之后有效(commit方法和close方法)
  • 查询的数据所转换的实体类类型必须实现序列化的接口Serializable

在这里插入图片描述

以上条件没有全部满足的时候,二级缓存开启失败:
在这里插入图片描述

二级缓存失效的情况:

两次查询之间执行了任意的增删改,会使一级和二级缓存同时失效

//注意
sqlSession.clearCache()方法,是SqlSession对象的方法

这个级别对应一级缓存,它清空不了二级缓存

二级缓存的相关配置:

二级缓存的一些配置,通过cache标签的各个属性来修改:

  • eviction属性:缓存回收策略
    。 LRU(Least Recently Used) – 最近最少使用的:移除最长时间不被使用的对象,默认的是 LRU
    。 FIFO(First in First out) – 先进先出:按对象进入缓存的顺序来移除它们
    。 SOFT – 软引用:移除基于垃圾回收器状态和软引用规则的对象
    。 WEAK – 弱引用:更积极地移除基于垃圾收集器状态和弱引用规则的对象

  • flushInterval属性:刷新间隔,单位毫秒
    。默认情况是不设置,也就是没有刷新间隔,缓存仅仅调用语句(增删改)时刷新

  • size属性:引用数目,正整数
    。 代表缓存最多可以存储多少个对象,太大容易导致内存溢出

  • readOnly属性:只读,true/false
    。 true:只读缓存;会给所有调用者返回缓存对象的相同实例。因此这些对象不能被修改。这提供了很重要的性能优势。
    。 false:读写缓存;会返回缓存对象的拷贝(通过序列化)。这会慢一些,但是安全,因此默认是false

1.3 MyBatis缓存查询的顺序

  • 先查询二级缓存,因为二级缓存中可能会有其他程序已经查出来的数据,可以拿来直接使用
  • 如果二级缓存没有命中,再查询一级缓存
  • 如果一级缓存也没有命中,则查询数据库
  • SqlSession关闭之后,一级缓存中的数据会写入二级缓存

1.4 整合第三方缓存EHCache

STEP1:先添加相关的依赖:


org.mybatis.cachesmybatis-ehcache1.2.1


ch.qos.logbacklogback-classic1.2.3

STEP2:resources目录下创建EHCache的配置文件ehcache.xml



在这里插入图片描述

STEP3:设置二级缓存的类型


STEP4:加入logback日志

//存在SLF4J时,作为简易日志的log4j将失
//此时需要借助SLF4J的具体实现logback来打印日志
//创建logback的配置文件logback.xml,名字固定

[%d{HH:mm:ss.SSS}] [%-5level] [%thread] [%logger] [%msg]%n

2、MyBatis的逆向工程

  • 正向工程:先创建Java实体类,由框架负责根据实体类生成数据库表。Hibernate是支持正向工程的
  • 逆向工程:先创建数据库表,由框架负责根据数据库表,反向生成如下资源:
    。 Java实体类
    。 Mapper接口
    。 Mapper映射文件

2.1 创建MyBatis逆向工程的步骤:

STEP1:添加相关的依赖和插件

org.mybatismybatis3.5.9junitjunit4.13.2testmysqlmysql-connector-java8.0.27log4jlog4j1.2.17


org.mybatis.generatormybatis-generator-maven-plugin1.3.0org.mybatis.generatormybatis-generator-core1.3.2com.mchangec3p00.9.2mysqlmysql-connector-java8.0.27

STEP2:新建mybatis核心配置文件(这一步无关逆向工程,只是为了写数据库信息,方便后面测试增删改查)




STEP3:创建逆向工程的配置文件,文件名固定generatorConfig.xml



STEP4:双击generator插件

在这里插入图片描述
构建成功:
在这里插入图片描述

2.2 方法使用说明

建议直接构建奢华尊享版MyBatis,增删改查。按条件、动态拼接这些都已经封装成了方法供调用,很方便:

在这里插入图片描述
部分方法使用举例:


/*** @author llg* @date 2023/3/10*/
public class testMBGTest {@Testpublic void testMBG(){try {InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);SqlSession sqlSession = sqlSessionFactory.openSession(true);EmpMapper empMapper = sqlSession.getMapper(EmpMapper.class);/*** 查询所有数据*/List empList = empMapper.selectByExample(null);empList.forEach(emp -> System.out.println(emp));/*** 根据条件查询*/EmpExample example = new EmpExample();example.createCriteria().andEmpNameEqualTo("甲").andAgeGreaterThan("16");example.or().andDidIsNotNull();List empList = empMapper.selectByExample(example);empList.forEach(emp -> System.out.println(emp));/*** 选择性修改* 即当某个属性为null的时候,该字段不会被更改* 以下即执行 update t_emp SET age = ? where eid = ? */empMapper.updateByPrimaryKeySelective(new Emp(1,null,"23",null,null,null));} catch (IOException e) {e.printStackTrace();}}
}
  • selectByExample:按条件查询,需要传入一个example对象或者null;如果传入一个null,则表示没有条件,也就是查询所有数据
  • example.createCriteria().xxx:创建条件对象,通过andXXX方法为SQL添加查询添加,每个条件之间是and关系
  • example.or().xxx:将之前添加的条件通过or拼接其他条件
  • updateByPrimaryKey:通过主键进行数据修改,如果某一个值为null,也会将对应的字段改为nul
  • updateByPrimaryKeySelective():通过主键进行选择性数据修改,如果某个值为null,则不修改这个字段

3.MyBatis分页插件

3.1 分页插件的配置步骤

STEP1:添加依赖


com.github.pagehelperpagehelper5.2.0

STEP2:配置分页插件

在MyBatis核心配置文件mybatis-config.xml中添加:



3.2 分页插件的使用

开启分页功能:

在查询功能之前使用PageHelper.startPage(int pageNum, int pageSize)开启分页功能

  • pageNum:当前页的页码
  • pageSize:每页显示的条数在查询功能之前开启分页
@Test
public void testPageHelper() throws IOException {InputStream is = Resources.getResourceAsStream("mybatis-config.xml");SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);SqlSession sqlSession = sqlSessionFactory.openSession(true);EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);//访问第2页,每页四条数据PageHelper.startPage(2,4);List emps = mapper.selectByExample(null);emps.forEach(emp -> System.out.println(emp));
}

在这里插入图片描述

Page对象

startPage方法返回的是一个Page对象,可以接收一下,并从中查看分页相关的数据:

Page page = PageHelper.startPage(1, 4);
System.out.println(page);
 

输出分页相关数据:

Page{count=true, pageNum=1, pageSize=4, startRow=0, endRow=4, total=8, pages=2, reasonable=false, pageSizeZero=false}[Emp{eid=1, empName='admin', age=22, sex='男', email='456@qq.com', did=3}, Emp{eid=2, empName='admin2', age=22, sex='男', email='456@qq.com', did=3}, Emp{eid=3, empName='王五', age=12, sex='女', email='123@qq.com', did=3}, Emp{eid=4, empName='赵六', age=32, sex='男', email='123@qq.com', did=1}]

PageInfo对象

在查询获取list集合之后,使用PageInfo pageInfo = new PageInfo<>(List list, intnavigatePages)获取分页相关数据

  • list:分页之后的数据
  • navigatePages:导航分页的页码数
@Test
public void testPageHelper() throws IOException {InputStream is = Resources.getResourceAsStream("mybatis-config.xml");SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);SqlSession sqlSession = sqlSessionFactory.openSession(true);EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);PageHelper.startPage(1, 4);List emps = mapper.selectByExample(null);PageInfo page = new PageInfo<>(emps,5);System.out.println(page);
}

返回数据:

PageInfo{
pageNum=1, pageSize=4, size=4, startRow=1, endRow=4, total=8, pages=2, 
list=Page{count=true, pageNum=1, pageSize=4, startRow=0, endRow=4, total=8, pages=2, reasonable=false, pageSizeZero=false}[Emp{eid=1, empName='admin', age=22, sex='男', email='456@qq.com', did=3}, Emp{eid=2, empName='admin2', age=22, sex='男', email='456@qq.com', did=3}, Emp{eid=3, empName='王五', age=12, sex='女', email='123@qq.com', did=3}, Emp{eid=4, empName='赵六', age=32, sex='男', email='123@qq.com', did=1}], 
prePage=0, nextPage=2, isFirstPage=true, isLastPage=false, hasPreviousPage=false, hasNextPage=true, navigatePages=5, navigateFirstPage=1, navigateLastPage=2, navigatepageNums=[1, 2]}

字段含义说明:

  • pageNum:当前页的页码
  • pageSize:每页显示的条数
  • size:当前页显示的真实条数
  • total:总记录数
  • pages:总页数
  • prePage:上一页的页码
  • nextPage:下一页的页码
  • isFirstPage/isLastPage:是否为第一页/最后一页
  • hasPreviousPage/hasNextPage:是否存在上一页/下一页
  • navigatePages:导航分页的页码数
  • navigatepageNums:导航分页的页码,[1,2,3,4,5]

相关内容

热门资讯

爵士舞蹈串词主持词   爵士舞即美国现代舞,是一种急促又富动感的节奏型舞蹈,是属于一种外放性的舞蹈,不像古典芭蕾舞或现代...
幼儿园元旦节目主持词   齐x:亲爱的爸爸妈妈  周x:亲爱的爷爷奶奶  王x:亲爱的老师  李x:亲爱的小朋友们  合:...
运动会运动员赞美词 运动会运动员赞美词1.赞运动员是我们的目标,是我们的信念,在清凉的初秋,在喧嚣的田径场上,。你们点燃...
黄梅戏晚会的主持词 黄梅戏晚会的主持词  戏迷欢庆四一八 黄梅又添新奇葩  ——喜迎418暨欢庆黄梅戏艺术团成立的晚会台...
学校秋季运动会开幕主持词 学校秋季运动会开幕主持词(精选6篇)  主持词要注意活动对象,针对活动对象写相应的主持词。在当今社会...
庆祝五四文艺晚会主持稿 庆祝五四文艺晚会主持稿  男:尊敬的各位领导、来宾  女:电视机前的观众朋友们  合:大家好  男:...
最新品鉴会主持词 最新品鉴会主持词  鉴会现在开始!  女:各位领导,各位嘉宾  男:女士们、先生们  合:大家下午好...
端午节晚会主持词 精选端午节晚会主持词(通用8篇)  根据活动对象的不同,需要设置不同的主持词。时代不断在进步,很多场...
论坛一周年庆典晚会主持词 论坛一周年庆典晚会主持词  主持词是由主持人于节目进行过程中串联节目的串联词。如今的各种演出活动和集...
最新研讨会主持词 最新研讨会主持词(通用11篇)  主持词分为会议主持词、晚会主持词、活动主持词、婚庆主持词等。在现在...
重阳节的主持词 重阳节的主持词  主持词分为会议主持词、晚会主持词、活动主持词、婚庆主持词等。在人们越来越多的参与各...
记者节活动主持词 记者节活动主持词(精选7篇)  主持词没有固定的格式,他的最大特点就是富有个性。在现今人们越来越重视...
高校运动会开幕式精彩致辞 高校运动会开幕式精彩致辞  在平平淡淡的学习、工作、生活中,大家肯定对各类致辞都很熟悉吧,致辞具有思...
幼儿园六一文艺演出主持词 幼儿园六一文艺演出主持词  20xx年六一文艺演出主持词  尊敬的各位领导、各位老师、亲爱的同学们:...
团拜会主持词 -主持词 团拜会主持词 -主持词大家下午好!腊梅催春至,瑞雪兆丰年!此时窗外虽然大雪纷飞、寒意袭人,但这里却热...
最新三八妇女节活动的主持词 最新三八妇女节活动的主持词(精选10篇)  主持词的写作需要将主题贯穿于所有节目之中。在现在的社会生...
小学师德报告会的主持词 小学师德报告会的主持词各位领导,各位老师:  大家下午好!采撷着金秋十月的累累硕果,收藏着金秋十月的...
《像小强一样儿活着》的经典台... 《像小强一样儿活着》的经典台词  《像小强一样活着》改编自同名网络小说,是难得的本土电影。曾有影评家...
汇演主持词 汇演主持词  主持词要根据活动对象的不同去设置不同的主持词。在人们积极参与各种活动的今天,主持人在各...
联欢会主持词结束语 联欢会主持词结束语(通用6篇)  晚会开得就是否成功圆满与主持人的讲话有很大关系。下面小编整理的联欢...