ppt教程从入门到精通,华为手机拍照技巧从入门到精通

今日分享开始啦,请大家多多指教~mybatis简介1 mybatis是什么MyBatis 是一款优秀的持久层框架MyBatis 避免了几乎所有的 JDBC 代码

今天开始分享,请大家多多指教~

mybatis简介

1 什么是Mybatis?

MyBatis 可以集成接口和Java 实体类来配置和映射原生信息,避免了几乎所有的JDBC 代码以及手动设置参数和检索结果集的过程。对象(常规Java 对象)被映射到数据库中的记录。eb694c6558f4427984010d308ee3b9b9~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=bkQEEFCsebRMrZDSfeIHCPIXTgs%3D

2 持久化和持久层

坚持

将原来存储在内存中的临时数据保存到持久存储设备中。 JDBC是一种持久化机制。文件IO也是一种持久化机制。持久化的需要是由持久化层的内存缺陷引起的。

完成持久化任务的代码块—-dao层【DAO(Data Access Object)】Mybatis的三大优点。

灵活分离SQL 和程序代码,而不影响应用程序。

mybatis快速构建

为了方便起见,您可以安装lombox 和Free Mybatis 插件。

流程:pom环境——mybatis-configxml配置文件——工具类——实体类——接口——接口实现类——测试类

1.pom.xml

2.mybatis-config.xml

3.SqlSessionUtil工具类(用于检索会话)

e460228a0b1249e89502d1345cf4fc94~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=0OTmYYb5df6FAHqV5eAXD0Qoi%2Bw%3D

4.实体类UserInf

c74e52e6a3ff4bb5a37bdd49bb39e6cf~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=EFK0is08QabWB5RFkszi6CWLRew%3D

5. 接口用户映射器

6.ListUserInf selectUser();

实现UserMapper.xml 接口

8be43f35a1964414897d3e43309f239e~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=D99Z90Yc9TxCWg0%2FEJNzps1j7Bo%3D

不要忘记在Mybatis-config.xml 中注册它。

d193496dc1c94ffea7b53a02871a709f~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=r8jDTjmqUlC4KzVyaDn%2BJXT9F9A%3D

7. 测试

5aad9a97aacb453a855ce985ec20989c~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=4DQPDBTYabzSTPeQX0U8c2uQ6Iw%3D

mybatis的增删改查

session.commit(); //提交事务,这是重点。如果不写的话,不会发送到数据库。

1 命名空间说明

命名空间映射器属性之一(命名空间)是映射器接口和XML 实现的唯一基础。

2 选型

在UserMapper接口中添加方法

//根据ID查询用户

UserInf selectUserById(@Param(‘id’)int id);

UserMapper.xml添加方法对应的映射

a9afa4bc6be044dd87eeb2a9fd59290c~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=WjBn3vj9gZw2U%2BdATfTwjKoz8Ic%3D

测试

a1919d84e4e645c29a450c4e1558d59b~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=byvALFKv1qJy61jDwnr3KTUvxnE%3D

3 插入

在UserMapper接口中添加方法

//添加用户信息

int addUserInf(UserInf userInf);

UserMapper.xml添加方法对应的映射

6bd6e2a5e57c48e2bf5bbf751803986c~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=N%2BWTepr5%2BTzTxB4Rrn5CgBwCUGk%3D

测试

f633d750b87d4b6295dba619ee499c89~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=7hLHLPBOJBFUZRCRHDojmpVu4xs%3D

4 条更新

在UserMapper接口中添加方法

//更改用户信息

int updateUserInf(UserInf userInf);

UserMapper.xml添加方法对应的映射

3c3276ebb6c94ad4b435c64c01a1bd0f~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=HKXujmecjM7UZcOsQ6e3VaF2xbQ%3D

测试

e0b0497f7fb047e7801d62f421d69e05~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=TzKnhcjft68iStDE6jgpUdoNkao%3D

5 删除

在UserMapper接口中添加方法

//根据id删除用户

int deleteUser(@Param(‘id’)int id);

UserMapper.xml添加方法对应的映射

91c00e29cb214333bdfa69ce01b177fa~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=Binm%2FDlM2b%2FTHYVsiBNPlbwpsGk%3D

测试

f75e634ccc384158b0424165e6ac4c60~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=hvuGdbUKCfzeWwcqFeTFlrtuTts%3D

6 模糊查询

类型1:将SQL 通配符添加到Java 代码中。

150391bab423413f97c3ca09ea5f9fae~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=HzZazkHoST%2BX8y62WLV50UckRlc%3D

类型2:在SQL语句中组合通配符会导致SQL注入。

43f01b81a1954e73a918593f4182b2c5~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=CEJEcaMy9N%2FGqjswwxagWbzlFqQ%3D

7 件事要记住

所有的添加、删除、修改操作都需要发送交易。

接口中所有常用参数一定要写@Param参数。特别是有多个参数的时候,更需要写。

在某些情况下,根据您的业务需求,您可以考虑使用映射来传递参数。

为了标准化操作,请尝试在SQL 配置文件中同时写入Parameter 参数和resultType。

mybatis配置详解

1 核心配置文件

mybatis-configig.xml 系统核心配置文件MyBatis 配置文件包含深刻影响MyBatis 行为的设置和属性信息。 一些属性和配置内容的说明:配置。

特性

环境

typeAliases(类型别名)

typeHandlers(类型处理程序)

objectFactory(对象工厂)

插件(插件)

环境(环境配置)

环境(环境变量)

交易经理

数据源(数据源)

databaseIdProvider(数据库供应商标识)

映射器

2环境(环境配置)

a74ea914ff574d52b3934381e97bdd0a~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=uRSrFF%2BqykdqoGo9xcO4XRHZZms%3D

根据业务需求,不同部门可能需要不同的环境。您可以配置多个环境,但一次只能使用一个,并且必须指定其中一个为默认运行环境(默认指定)。

子元素节点:环境

您可以通过设置ID 来区分一组特定的环境。 ID 保证是唯一的。

子元素节点:transactionManager – [事务管理器] MyBatis 中有两种类型的事务管理器(即type='[JDBC|MANAGED]’)。单独的mybatis上不需要额外配置。

子元素节点:dataSource dataSource 元素使用标准JDBC 数据源接口为JDBC 连接对象配置资源。

共有三种内置数据源类型(type=”[UNPOOLED|POOLED|JNDI]’))。

三个地图绘制者

Mapper : 定义映射SQL语句文件

3.1 不同的资源部署方式

df3c99fb5ed1447ea32ad58086973994~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=vhywlmbsm4He7kpMUvtU7ibc7nU%3D

a193cd615397404ca52825eccd929913~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=39L6GYAIoIqW8I5TJSJVeZ0XaaY%3D

&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=oglH3X%2B2c1StlpnJa4jt2DcWkwA%3D” alt=”4d5240c6580d444cb414219fbbe72376~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=oglH3X%2B2c1StlpnJa4jt2DcWkwA%3D” />
3.2 Mapper文件模板
d760b6deb383460ba735038bd1fa2893~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=9EdlPSV7ShtHeT%2Ff6okE2JGO5S4%3D
4 properties(属性)
properties 属性可以利用配置文件或者java代码来动态更改在多处中配置了属性时,propertie中的值会被resouce中的覆盖,会被java代码中的方法传参覆盖。可以采用占位符的形式来配置属性默认值官方文档4.1使用配置文件优化
新建config.properties
导入配置文件并占位符显示属性值
89873754bcee4a47a1c5428235bb684c~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=ZrGHvipmBGKhsYJB%2FPaulBKmP3o%3D
5 typeAliases(别名)
为解决包名过长问题的代码冗余。
第一种方式
d4e5a6802e5f49ce9d1c8fee26435f73~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=zXHWv%2Beg%2F76S8bsZtKcVCfiypPc%3D
在所有使用com.lyj.entity.UserInf的地方都可以用User代替
第二种方式
e9814f424a614db6bf5757319222a24c~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=MDhvqJuSfxV58zS%2FkHYJQbGDmdQ%3D
在com.lyj.entity包下的所有实体类都可以使用类名首字母小写的方式引用(如com.lyj.entity.UserInf用userInf代替)
也可以在实体类加上注解的方式自定义别名
@Alias(“user”)
public class UserInf { … }
6 settings(设置)
可以为mybatis增加设置
数据库驼峰名转换设置
9b88dd0192b0466d81d1be525bbc44bf~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=%2FwhIjXZTl%2FH508O4jvjzmPM1768%3D
log日志设置显示
<setting name=”logImpl” value=”STDOUT_LOGGING”/>

ResultMap(结果集映射)

为了解决数据映射问题而生
1 解决数据库与实体类属性名不一致问题
解决的问题:属性名和字段名不一致
因为各种原因,数据库的属性字段无法和实体类的属性字段一一对应。
举例:
现在数据库表属性为:
64d6aa90fb4244faa7d35c8e0f1ea8f3~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=slSfA%2F%2FULQAP4MzuMcS3NJl6w%2F0%3D
实体类属性值为:
c378ad9b4d574fbd9ffae3bbbf73be29~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=GrWPTlxiwQOw2J0icRWhjjpp24U%3D
查询语句:
6714f9c3cb134c8d8351afe53c940b87~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=LPM%2FuQ2uL%2B2XJjeWTBGT%2BMHfC7s%3D
这样查询,因为pwd在实体类中并不存在,在注入值时无法注入。出现password属性为空的情况。
解决方案
使用别名(可简写 pwd password)
22109050e1814426abca0a0f871f3345~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=HZGNJYJl6FySZiXAinX6G3iWT%2FE%3D
使用结果集映射->ResultMap 【推荐】
865fda38802b400c9112d002dd33411b~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=Nh4nzx3YglJzJzPFe99McBTweTs%3D
2 解决多对一结果集映射(association关联属性)
多对一理解:
多个学生对应一个老师。数据库概念理解:学生拥有一个tid与教师id对应。实体类概念理解:学生拥有一个教师对象。2.1 按查询嵌套处理
实体类student和teacher
bf76991ca1ed4d53a867efa023022363~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=jXFekwVLKxwh2J%2F3KfdQMU4wozI%3D
StudentMapper增加接口
//查询所有学生
public List<Student> queryAllStudents();
StudentMapper.xml增加对应方法(对于对象属性teacher采用关联属性)
c8967d373d1f4ac486ab52e14d84b50b~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=TCWG1RvPxezF7C1V7PkVCDWUcA4%3D
测试(对于对象属性teacher的属性采用关联属性)
2c099887a5324f2fbc3ef7ccf2cfa4f5~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=nFf7a%2BusxFtBxiJxZ3nAkhM9V%2BY%3D
2.2 按结果嵌套处理。
83d8ecc0e67147a88dffeffc2b2a04c2~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=a95tRlsEzccGbzEDurU6CHanfts%3D
3解决一对多结果集映射(collection集合)
一对多理解:
一个老师有多个学生数据库概念理解:教师拥有一个id与学生tid对应。实体类概念理解:教师拥有一个学生对象List集合。3.1 按查询嵌套处理。
实体类Student和Teacher
4df3e96a36f24961a0220fafaa81a6cf~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=5P8eCq%2BRBVsGHDDM6%2BMUMVN%2FBkw%3D
TeacherMapper增加方法
public Teacher getTeacher(int id);
TeacherMapper.xml增加实现
26e7b31cd9254cb6b987ef4ae386f100~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=QBWyK0J68UVCVsyX3LJztA6vxsk%3D
测试
3c582126c9a84e3d9beb56f3ef3d16e7~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=B8NjN7OrjxS0lwYzfeW9YvkPMyA%3D
3.2 按结果嵌套处理
1c189cdaadf747cfad99c40536ae6e7d~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=9xT9BrxfimxfxRTgZ4Np%2BJSUg20%3D

动态SQL

动态SQL指的是根据不同的查询条件 , 生成不同的Sql语句。
1 环境
utils工具类:随机生成id
478621c668804bfca32f75de699653a6~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=bBLuJpSWlVJjoQ2CbVn6mE%2F7KUQ%3D
entity实体类
df857362cd474f8c92710c9fb7383dd9~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=7hoJxPT9GrBdXjfC5GFgwOzxS2Y%3D
其他正常布置,数据库添加数据。
2 if语句
需求:根据作者名字和博客名字来查询博客!如果作者名字为空,那么只根据博客名字查询,反之,则根据作者名来查询
xml文件实现
3f4f80feb21143b5b9d6de03592d2a42~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=eyzaS5MtE5w8m9lH%2FiEa2ey2VNE%3D
注意:在依次执行所有的if语句,因此当title为空,author不为空时,产生错误。引入where
3 where语句
xml文件实现
6f008e886f9845c4ae4a97638e461b14~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=Q6WIqpxL%2BeejkUyKt6lB6L3Ns40%3D
注意:当where包含的标签有返回值时能够自动加上where字符,同时当检测标签开头含有 AND或 OR 字符时,会将字符除去。
4 choose语句
利用if 和where搭配已经能够解决大部分的SQL查询拼接,但是有时候我们需要某一个条件不为空时立即跳出不在接受参数。这个时候我们可以利用choose实现,相当于编程语言中的 switch。
xml实现:
b12edf43ece042e3928582a3890c31a7~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=KnqY569fpTwFKgeIvdpfQmLjdL0%3D
读起来十分有switch-case-otherwise的既视感。
5 foreach语句
foreach 相当于for循环,当我们需要一次性查询多个内容时,可以用foreach来实现这一功能。
16cfdde4e66d44bd8216525deeea3cd9~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=vWMn7FSsdp2WtY0ip2GhkV%2F5m4s%3D
测试:
3190f8b274234edfb915db07664a62bb~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=ATHiIBs6oGHfoXix0XzLt6vWPV4%3D
相当于SQL语句:select * from blog where (id=1 or id=2 or id=3)
6 set语句
当我们需要进行修改操作时,set的操作配合if使用会现之前查询出现的问题。
不用set标签之前,当author为空时,名=SQL语句拼接就会出错,这个时候使用set标签可以很好的解决这个问题。
4ccc2013c7a54410b00f1b4306d8bd56~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=THjb545Q6%2Blveqbhc4uj7lSpw48%3D
使用set标签后
3d3b0a19008b429ab42e252821a52477~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=jccCPXFeydczaQOa1H6seynirCE%3D
**set标签的功能和where类似,先是内部标签有返回值时会自动补充set字符,当内部标签结尾含有,字符时,会自动去除 **
7 SQL片段
在正常的数据查询流程中,直接使用select *对数据安全来说无疑是十分危险的,我们会使用字段的形式来代替这种方式,但是字段过多的情况下,每次重复的复制代码过于麻烦且不容易维护。这个时候自定义SQL片段可以很好的解决这个问题。
248c6033af7f4cf889738da748d4e6dc~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=0xd34CuJmKK75UjKPcRPT4VhM74%3D
sql标签和incloud标签配合使用很好的实现了这个功能。

日志工厂与分页

1 日志工厂
mybatis可以通过配置日志的方式来过程信息,可以采用自带的日志工厂,也可以用第三方包。
Mybatis内置的日志工厂提供日志功能,具体的日志实现有以下几种工具:
SLF4JApache Commons LoggingLog4j 2Log4jJDK logging标准日志实现:
d79e2b3540bb4c83bd2ff9857b2dd182~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=uHhPplIaDKEPMHj3IgCpu7sJ1G8%3D
2 Log4j
通过使用Log4j,我们可以控制日志信息输送的目的地:控制台,文本,GUI组件…
我们也可以控制每一条日志的输出格式;
使用:
导包
af07e1da149c471c8b6368c49f382c8c~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=9KFQCcNkZoGgbmeUUQ%2FsDB0zHYs%3D
更改日志工厂设置
1a89117d46d5421aa7364e8e99d5aa73~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=WNUoBWW8XD4y5KGpRK59e%2FCM5hg%3D
新建配置文件log4j.properties
dc2fa767a5de493ba66699ef7c53994b~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=RfJvTboia0eMyXAawQ%2By2aQQWUk%3D
使用
f8431c72d9d042c38cc04c0d34aac0fc~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=MbJXfpxUeLhOsWS2BM6kDgwHqOI%3D
**注意:**log4j导包使用的是apache的包,会自动在当前目录生成一个log文件夹,可以显示log记录。
3 limit实现分页
**分页:**记得以前一个javaweb项目当中,老师要求使用java代码来实习分页查询。那个时候是使用了一个工具类来专门处理分页逻辑,现在回顾过去,也不是十分困难。
主要有两个方法,一是在MySQL层次上处理,另一个是在java代码层次上。
3.1 分页实现
mysql语法:
0de0066b6d004ab584a61e8c766b0c82~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=2jt5La3z6aphWcnC%2FHK9Fz%2FigVo%3D
步骤:
SQL语句
18477129c3e74256bb2887bda273b48e~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=DIyI9VNwf5jqlWg6OObkPhE6brc%3D
如果我们有很多种不同的分页类型,为每一个不同的类型写不同的工具类就会让代码十分的冗余,用泛型可以解决这一问题。
blog实体类
353c18eb2ade42d58f2dcb44d94bc6b3~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=fal7IxdD8XBJ2zkiadOlupkaH1c%3D
PageModel泛型类,来实现一个基本的分页数据。
035ee68ca0fb4c43a98fff980357b6e1~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=VV4%2FSmsTLXYRPIxxN1NO9hR4vyQ%3D
如果想要在PageModel的基础上加上具有不同分页特色的数据,那么可以用继承来实现。
0300db6e52de4f2994ef1ddbfcb9b5d7~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=n85GbZ65o03d%2F7KgTTELWXTjc%2Bg%3D
工具类处理
7fe3991fbe0441259cce71f7f74d3421~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=07dnZRzGsp%2Bh%2FJPZq%2B3%2Fk1cfJ38%3D
测试类
9093b8a0d5b945b081bfa56f1165553c~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=VkwRgDPiAEQoo3iZ4l%2F1VNzUY%2FM%3D
之前以为这样就完成了分页,没想到始终无法将Mapper抽象出来,这个分页是不合格的。
3.2 RowBounds分页
使用方法
3.3 PageHelper
使用方法

mybatis缓存

1 简介
什么是缓存 [ Cache ]?
存在内存中的临时数据。将用户经常查询的数据放在缓存(内存)中,用户去查询数据就不用从磁盘上(关系型数据库数据文件)查询,从缓存中查询,从而提高查询效率,解决了高并发系统的性能问题。为什么使用缓存?
减少和数据库的交互次数,减少系统开销,提高系统效率。什么样的数据能使用缓存?
经常查询并且不经常改变的数据。2 Mybatis缓存
MyBatis包含一个非常强大的查询缓存特性,它可以非常方便地定制和配置缓存。缓存可以极大地提升查询效率。
MyBatis系统中默认定义了两级缓存:一级缓存和二级缓存
默认情况下,只有一级缓存开启。(SqlSession级别的缓存,也称为本地缓存)二级缓存需要手动开启和配置,它是基于namespace级别的缓存。为了提高扩展性,MyBatis定义了缓存接口Cache。我们可以通过实现Cache接口来自定义二级缓存3 一级缓存
一级缓存也称为本地缓存。
默认开启的。
SqlSession级别的缓存。
在同一个session中我们执行同一个查询,将不会重复的去sql读取,而是从缓存中去读取。
3.1 一级缓存失效的四种情况
sqlSession不同sqlSession相同,查询条件不同sqlSession相同,两次查询之间执行了增删改操作!sqlSession相同,手动清除一级缓存。session.clearCache();//手动清除缓存
4 二级缓存
二级缓存也叫全局缓存,一级缓存作用域太低了,所以诞生了二级缓存
基于namespace级别的缓存,一个名称空间,对应一个二级缓存;
工作机制
一个会话查询一条数据,这个数据就会被放在当前会话的一级缓存中;如果当前会话关闭了,这个会话对应的一级缓存就没了;但是我们想要的是,会话关闭了,一 级缓存中的数据被保存到二级缓存中;新的会话查询信息,就可以从二级缓存中获取内容。不同的mapper查出的数据会放在自己对应的缓存(map)中;4.1 二级缓存的使用
mybatis-config.xml开启全局缓存
61fd42350d1e44c1afd0a5d16d85be36~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=GfNWekLNATS6H5yxViQiI%2BnqlZ8%3D
在要开启缓存的namespace缓存配置官方文档
<cache eviction=”FIFO” flushInterval=”60000″ size=”512″ readOnly=”true”/>
#这个更高级的配置创建了一个 FIFO 缓存,每隔 60 秒刷新,最多可以存储结果对象或列表的 512 个引用,而且返回的对象被认为是只读的,因此对它们进行修改可能会在不同线程中的调用者产生冲突。
测试
ec48ae883b3241fb9cb01c4a26742818~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=VaJxs7p4e95%2FFujqRmPSRqAkFC4%3D
只有session结束之后,数据才会从一级缓存中存放到二级缓存中去。
5 第三方缓存EhCache
导入相应依赖
8de58c4550554a8f88f13f330d8f78a2~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=jIZDN9UeTmpgy9ft42FtlNneMf0%3D
在对应的mapper配置文件中开启EhCache。
<cache type = “org.mybatis.caches.ehcache.EhcacheCache” />
新建一个ehcache.xml文件
a72c782b766e439d8cc6fbd5de3e7b18~noop.image?_iz=58558&from=article.pc_detail&lk3s=953192f4&x-expires=1717788967&x-signature=vf4l8KQ2%2BzTQoCLXQAq9kc2N4Tg%3D
今日份分享已结束,请大家多多包涵和指点!

原创文章,作者:小条,如若转载,请注明出处:https://www.sudun.com/ask/84158.html

Like (0)
小条的头像小条
Previous 2024年6月1日 上午3:19
Next 2024年6月1日 上午3:36

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注