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

相关内容

热门资讯

常用商务英语口语   商务英语是以适应职场生活的语言要求为目的,内容涉及到商务活动的方方面面。下面是小编收集的常用商务...
六年级上册英语第一单元练习题   一、根据要求写单词。  1.dry(反义词)__________________  2.writ...
复活节英文怎么说 复活节英文怎么说?复活节的英语翻译是什么?复活节:Easter;"Easter,anniversar...
2008年北京奥运会主题曲 2008年北京奥运会(第29届夏季奥林匹克运动会),2008年8月8日到2008年8月24日在中华人...
英语道歉信 英语道歉信15篇  在日常生活中,道歉信的使用频率越来越高,通过道歉信,我们可以更好地解释事情发生的...
六年级英语专题训练(连词成句... 六年级英语专题训练(连词成句30题)  1. have,playhouse,many,I,toy,i...
上班迟到情况说明英语   每个人都或多或少的迟到过那么几次,因为各种原因,可能生病,可能因为交通堵车,可能是因为天气冷,有...
小学英语教学论文 小学英语教学论文范文  引导语:英语教育一直都是每个家长所器重的,那么有关小学英语教学论文要怎么写呢...
英语口语学习必看的方法技巧 英语口语学习必看的方法技巧如何才能说流利的英语? 说外语时,我们主要应做到四件事:理解、回答、提问、...
四级英语作文选:Birth ... 四级英语作文范文选:Birth controlSince the Chinese Governmen...
金融专业英语面试自我介绍 金融专业英语面试自我介绍3篇  金融专业的学生面试时,面试官要求用英语做自我介绍该怎么说。下面是小编...
我的李老师走了四年级英语日记... 我的李老师走了四年级英语日记带翻译  我上了五个学期的小学却换了六任老师,李老师是带我们班最长的语文...
小学三年级英语日记带翻译捡玉... 小学三年级英语日记带翻译捡玉米  今天,我和妈妈去外婆家,外婆家有刚剥的`玉米棒上带有玉米籽,好大的...
七年级英语优秀教学设计 七年级英语优秀教学设计  作为一位兢兢业业的人民教师,常常要写一份优秀的教学设计,教学设计是把教学原...
我的英语老师作文 我的英语老师作文(通用21篇)  在日常生活或是工作学习中,大家都有写作文的经历,对作文很是熟悉吧,...
英语老师教学经验总结 英语老师教学经验总结(通用19篇)  总结是指社会团体、企业单位和个人对某一阶段的学习、工作或其完成...
初一英语暑假作业答案 初一英语暑假作业答案  英语练习一(基础训练)第一题1.D2.H3.E4.F5.I6.A7.J8.C...
大学生的英语演讲稿 大学生的英语演讲稿范文(精选10篇)  使用正确的写作思路书写演讲稿会更加事半功倍。在现实社会中,越...
VOA美国之音英语学习网址 VOA美国之音英语学习推荐网址 美国之音网站已经成为语言学习最重要的资源站点,在互联网上还有若干网站...
商务英语期末试卷 Part I Term Translation (20%)Section A: Translate ...