首页 > 其他分享 >浅析 MyBatis 中的连接池和缓存

浅析 MyBatis 中的连接池和缓存

时间:2024-09-12 18:23:36浏览次数:13  
标签:缓存 数据库 查询 二级缓存 MyBatis 浅析 连接池

文章目录


在使用 MyBatis 进行 Java 应用开发时,连接池和缓存是两个非常重要的特性,它们可以极大地提高应用的性能和效率。本文将对 MyBatis 中的连接池和缓存进行浅析。

一、MyBatis 简介

MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Old Java Objects)映射成数据库中的记录。

二、连接池

1. 连接池的作用

在数据库操作中,建立数据库连接是一项比较耗时的操作。如果每次执行数据库操作都创建一个新的连接,会严重影响应用的性能。连接池的作用就是管理数据库连接,减少连接创建和销毁的开销,提高数据库访问的效率。

2. MyBatis 中的连接池实现

MyBatis 支持多种连接池实现,默认使用的是 PooledDataSourcePooledDataSource 是 MyBatis 自己实现的连接池,它基于传统的连接池设计模式,通过维护一组数据库连接,在需要时分配连接,使用完毕后回收连接。
以下是一个使用 MyBatis 连接池的配置示例:

<configuration>
	<environments default="development">
		<environment id="development">
			<transactionManager type="JDBC"/>
			<dataSource type="POOLED">
				<property name="driver" value="com.mysql.jdbc.Driver"/>
				<property name="url" value="jdbc:mysql://localhost:3306/mydb"/>
				<property name="username" value="root"/>
				<property name="password" value="password"/>
			</dataSource>
		</environment>
	</environments>
	<mappers>
		<mapper resource="mapper/UserMapper.xml"/>
	</mappers>
</configuration>

在上述配置中,通过设置 <dataSource type="POOLED"> 来启用 MyBatis 的连接池。同时,配置了数据库驱动、连接 URL、用户名和密码等信息。

3. 连接池的参数配置

MyBatis 的连接池可以通过一些参数进行配置,以满足不同的应用需求。以下是一些常见的参数:

  • poolMaximumActiveConnections:连接池中最大活动连接数。
  • poolMaximumIdleConnections:连接池中最大空闲连接数。
  • poolMaximumCheckoutTime:连接在连接池中被检出的最长时间(以毫秒为单位)。
  • poolTimeToWait:当没有可用连接时,连接池等待获取连接的最长时间(以毫秒为单位)。

例如,可以通过以下方式配置连接池的参数:

<dataSource type="POOLED">
	<property name="driver" value="com.mysql.jdbc.Driver"/>
	<property name="url" value="jdbc:mysql://localhost:3306/mydb"/>
	<property name="username" value="root"/>
	<property name="password" value="password"/>
	<property name="poolMaximumActiveConnections" value="10"/>
	<property name="poolMaximumIdleConnections" value="5"/>
	<property name="poolMaximumCheckoutTime" value="20000"/>
	<property name="poolTimeToWait" value="15000"/>
</dataSource>

三、缓存

1. 缓存的作用

缓存的目的是为了减少对数据库的访问次数,提高数据查询的性能。当执行相同的查询语句时,如果查询结果已经在缓存中,则可以直接从缓存中获取结果,而不需要再次执行数据库查询操作。

2. MyBatis 的一级缓存

MyBatis 提供了一级缓存,也称为本地缓存。一级缓存是默认开启的,它作用于 SqlSession 级别。当一个 SqlSession 执行查询操作时,MyBatis 会先从一级缓存中查找是否有相同的查询结果。如果有,则直接返回缓存中的结果;如果没有,则执行数据库查询操作,并将查询结果放入一级缓存中。
以下是一个使用 MyBatis 一级缓存的示例:

SqlSession sqlSession = sqlSessionFactory.openSession();
try {
	UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
	// 第一次查询,会执行数据库查询操作,并将结果放入一级缓存
	User user1 = userMapper.getUserById(1);
	// 第二次查询,会从一级缓存中获取结果,不会执行数据库查询操作
	User user2 = userMapper.getUserById(1);
} finally {
	sqlSession.close();
}

需要注意的是,一级缓存的作用范围仅限于同一个 SqlSession。如果在不同的 SqlSession 中执行相同的查询操作,MyBatis 会重新执行数据库查询操作。

3. MyBatis 的二级缓存

MyBatis 的二级缓存是基于命名空间(mapper namespace)的缓存。二级缓存可以在多个 SqlSession 之间共享,因此可以提高数据查询的性能。
要启用 MyBatis 的二级缓存,需要在对应的 Mapper XML 文件中添加 <cache/> 元素。例如:

<mapper namespace="com.example.UserMapper">
	<cache/>
	<select id="getUserById" resultType="User">
		SELECT * FROM user WHERE id = #{id}
	</select>
</mapper>

在上述配置中,通过添加 <cache/> 元素启用了二级缓存。当执行 getUserById 查询时,查询结果会被放入二级缓存中,以便在后续的查询中可以直接从缓存中获取结果。
二级缓存的作用范围是整个命名空间,即同一个 Mapper 中的所有查询语句都可以共享二级缓存。但是,不同的命名空间之间的缓存是独立的。

4. 缓存的刷新和清空

MyBatis 的缓存可以通过一些方式进行刷新和清空。例如,当执行数据库的插入、更新或删除操作时,MyBatis 会自动清空相关的缓存,以保证缓存中的数据与数据库中的数据一致。
此外,还可以通过调用 SqlSessionclearCache() 方法手动清空一级缓存。对于二级缓存,可以通过设置 cache 元素的 flushInterval 属性来指定缓存自动刷新的时间间隔。

四、总结

MyBatis 中的连接池和缓存是提高应用性能的重要手段。连接池可以减少数据库连接创建和销毁的开销,提高数据库访问的效率;缓存可以减少对数据库的访问次数,提高数据查询的性能。在实际应用中,可以根据具体的需求对连接池和缓存进行合理的配置和使用,以达到最佳的性能效果。
通过对 MyBatis 中的连接池和缓存的浅析,我们可以更好地理解和使用这两个重要的特性,从而提高应用的开发效率和性能。

标签:缓存,数据库,查询,二级缓存,MyBatis,浅析,连接池
From: https://blog.csdn.net/dawn191228/article/details/142029667

相关文章

  • MyBatis-Plus动态表名
    MyBatis-Plus动态表名一、早期方案1.1MyBatis-Plus版本1、添加MyBatis-Plus依赖<dependency>   <groupId>com.baomidou</groupId>   <artifactId>mybatis-plus-boot-starter</artifactId>   <version>3.5.1</version></dependency>......
  • Mybatis读取和存储json类型的数据
    目录一、测试使用JSONObject来获取json二、设置@TableName的autoResultMap为true,@TableField的typeHandler为JacksonTypeHandler.class三、设置xml当中的resultMap四、JacksonTypeHandler讲解五、新增假如是JSONObject异常问题六、遇到转义的问题不管数据库当中是以json还是longte......
  • 滚雪球学MyBatis(12):常见问题与解决方案
    前言欢迎回到我们的MyBatis系列教程。在前几期中,我们已经进行了MyBatis的基础使用、进阶功能及项目实战的详细讲解。通过这些内容,相信大家对MyBatis有了全面的了解,并能够在实际项目中应用MyBatis。然而,在使用MyBatis的过程中,我们可能会遇到各种问题。本期内容中,我们将总结......
  • 滚雪球学MyBatis(13):总结与展望
    前言欢迎回到我们的MyBatis系列教程。在前几期中,我们从基础到进阶,详细讲解了MyBatis的各个方面,并通过项目实战帮助大家巩固所学知识。本期内容中,我们将对整个系列教程进行总结与回顾,并展望未来的学习方向。通过这一期的内容,希望大家能够全面回顾MyBatis的核心知识点,并了解......
  • spring如何整合druid连接池?
    spring整合druid连接池 1.新建maven项目打开IDE(比如IntelliJIDEA,Eclipse等)。选择新建项目:在IntelliJIDEA中,选择File>New>Project。在Eclipse中,选择File>New>MavenProject。选择Maven项目模板:在IntelliJIDEA中,选择Archetype选项卡,并搜索或选择一个适......
  • springboot 整合 mybatis-plus
    在创建springboot模块时,依赖勾选时没有mybaits-plus选项,原因是其未被加入。所以必须要手动引入依赖<dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.5.7</vers......
  • 第四章 Mybatis 核心组件介绍
    一、Configuration Executor MappedStatementMyBatis3的核心组件中,Configuration、Executor 和 MappedStatement 是非常关键且相互关联的部分,它们共同构成了MyBatis框架的基础架构,用于管理SQL映射和执行数据库操作。ConfigurationConfiguration 类是MyBatis......
  • 17个Mybatis Plugs注解:Mybatis Plugs插件架构设计与注解案例(必须收藏)
    MyBatisPlugins框架提供了一种强大而灵活的机制,允许开发者通过实现Interceptor接口来扩展MyBatis的核心功能。这种插件化的方法无需修改MyBatis源码,即可引入诸如性能监控、日志记录、数据加密、查询缓存等额外功能。通过注解如@Intercepts、@Signature等,开发者可以精确地......
  • 23个Mybatis注解:Mybatis架构分析与注解案例(必须收藏)
    MyBatis是一款优秀的持久层框架,它通过提供数据访问对象(DAO)和数据访问层(DAL)的抽象,简化了数据库交互的复杂性。利用注解如@Select、@Insert、@Update、@Delete,MyBatis支持定制化SQL、存储过程以及高级映射,使得开发者能够灵活地处理数据库操作。其核心特性包括动态SQL构......
  • Mybatis踩坑记录:探究Mybatis源码为何当传入参数Integer类型为0时,if条件生效
    目录前言 ​编辑问题背景 深入源码 解决问题方案一方案二方案三 结果结语前言在MyBatis中,<if>标签用于动态生成SQL查询条件。然而,在一些特定的场景下,<if>标签的条件判断可能会出现意料之外的结果。例如,当传入的Integer参数为0时,条件判断可能不会如......