【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]

相关内容

热门资讯

我家的爪哇木棉树四年级作文【... 我家的爪哇木棉树四年级作文 篇一我家的爪哇木棉树我家的院子里有一棵高大而繁茂的爪哇木棉树。它是我们家...
避暑山庄作文400字四年级【... 避暑山庄作文400字四年级 篇一避暑山庄是我家附近最有名的旅游景点之一。每年夏天,当天气变得炎热,我...
四年级上册作文胜似亲人300... 四年级上册作文胜似亲人300字 篇一我的好朋友小明我有一个好朋友,他叫小明。我们从幼儿园就认识了,现...
四年级种草莓作文300字(精... 四年级种草莓作文300字 篇一四年级种草莓我家有一块小菜园,爸爸妈妈带我一起种了许多蔬菜和水果。其中...
四年级游太公湖暑假作文(精简... 四年级游太公湖暑假作文 篇一我和家人一起游太公湖暑假到了,我和家人决定去太公湖游玩。太公湖是我们城市...
菊花四年级作文(实用6篇) 菊花四年级作文 篇一菊花的美丽我最喜欢的花是菊花,因为它们有着独特的美丽和芬芳的香味。每当秋天来临,...
四年级小学生家长寄语【优质6... 四年级小学生家长寄语 篇一亲爱的宝贝,你已经进入了四年级,我感到非常骄傲和自豪。这一年,你将会面临更...
小学四年级写景作文(通用6篇... 小学四年级写景作文 篇一:美丽的夏日公园今天是个晴朗的夏日,在我家附近有一个美丽的公园,我和妈妈一起...
小学四年级作文我的家乡衢州【... 小学四年级作文我的家乡衢州 篇一我家乡衢州是一个美丽而古老的城市。它位于浙江省中部,是一个历史悠久的...
和恐龙在一起四年级语文作文(... 和恐龙在一起四年级语文作文 篇一四年级的我有一个非常奇妙的朋友,他就是一只恐龙。虽然恐龙在人类的眼中...
四年级与安全有关的作文24篇... 四年级与安全有关的作文24篇 篇一标题:如何保护自己的个人隐私个人隐私是每个人都应该尊重和保护的重要...
小区里的猫四年级作文400字... 小区里的猫四年级作文400字 篇一小区里的猫我家住在一个安静而美丽的小区里,小区里有一只可爱的猫。这...
四年级300字想象篇作文怎么... 四年级300字想象篇作文怎么写 篇一我喜欢想象,想象可以让我进入一个神奇的世界。我可以想象自己是一只...
感动那一瞬间四年级作文500... 感动那一瞬间四年级作文500字88篇 篇一:爸爸的温暖拥抱那是一个寒冷的冬日,我正坐在教室里,心里有...
四年级的作文【经典6篇】 四年级的作文 篇一:我喜欢的动物作文一:我喜欢的动物我喜欢的动物是小狗。小狗是一种忠诚、可爱的动物。...
军训生活作文【经典3篇】 军训生活作文 篇一军训生活是一段难忘的经历,它不仅锻炼了我们的体魄,也培养了我们的意志品质。回想起那...
最美的秋天四年级作文大全【精... 最美的秋天四年级作文大全 篇一秋天是我最喜欢的季节,因为它给我带来了无数的美好回忆和欢乐时光。每当秋...
我的家乡大草原作文400字四... 我的家乡大草原作文400字四年级29篇 篇一:美丽的大草原我的家乡是一片美丽的大草原。大草原上绿草如...
神奇的魔法球四年级作文(最新... 神奇的魔法球四年级作文 篇一一天放学后,我在回家的路上发现了一个闪闪发光的球,它看起来非常神奇。我好...
我的榜样四年级作文(优选6篇... 我的榜样四年级作文 篇一我的榜样是我的爸爸。他是一个非常勤劳和有责任心的人。我记得有一次,我生病了,...