数据源HiKariCP与MyBatis整合

为什么使用HiKariCP

在Springboot2.X版本,数据库的连接池官方推荐使用HikariCP,官方的原话:

  1. 我们更喜欢HikariCP的性能和并发性。如果有HikariCP,我们总是选择它
  2. 否则,如果Tomcat池数据源可用,我们将使用它。
  3. 如果HikariCP和Tomcat池数据源都不可用,如果Commons DBCP2可用,我们将使用它。

如何使用HiKariCP

如果你的springboot版本是2.X
当你使用spring-boot-starter-jdbc或者spring-boot-starter-data-jpa依赖
springboot就会自动引入HikariCP的依赖了。

整合HiKariCP

1.pom中引入数据源驱动与mybatis依赖

<!-- mysql驱动 -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
</dependency>
<!-- mybatis -->
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>2.1.0</version>
</dependency>

2.在yml中配置数据源和mybatis

2.1 配置数据源信息

############################################################
#
# 配置数据源信息
#
############################################################
spring:
  profiles:
    active: dev
  datasource:                                           # 数据源的相关配置
    type: com.zaxxer.hikari.HikariDataSource          # 数据源类型:HikariCP
    # 这里根据自己的版本来决定
    # 低版本使用com.mysql.jdbc.Driver
    # 高版本使用com.mysql.cj.jdbc.Driver
    driver-class-name: com.mysql.cj.jdbc.Driver          # mysql驱动
#    url: jdbc:mysql://localhost:3306/foodie-shop-dev?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true
    username: root
#    password: root
    hikari:
      connection-timeout: 30000       # 等待连接池分配连接的最大时长(毫秒),超过这个时长还没可用的连接则发生SQLException, 默认:30秒
      minimum-idle: 5                 # 最小连接数
      maximum-pool-size: 20           # 最大连接数
      auto-commit: true               # 自动提交
      idle-timeout: 600000            # 连接超时的最大时长(毫秒),超时则被释放(retired),默认:10分钟
      pool-name: DateSourceHikariCP     # 连接池名字
      max-lifetime: 1800000           # 连接的生命时长(毫秒),超时而且没被使用则被释放(retired),默认:30分钟 1800000ms
      connection-test-query: SELECT 1
  servlet:
    multipart:
      max-file-size: 512000     # 文件上传大小限制为500kb
      max-request-size: 512000  # 请求大小限制为500kb

2.2 mybatis配置

############################################################
#
# mybatis 配置
#
############################################################
mybatis:
  type-aliases-package: com.imooc.pojo          # 所有POJO类所在包路径
  mapper-locations: classpath:mapper/*.xml      # mapper映射文件
#  configuration:
#    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

3.内置tomcat

############################################################
#
# web访问端口号  约定:8088
#
############################################################
server:
#  port: 8088
  tomcat:
    uri-encoding: UTF-8
  max-http-header-size: 80KB
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring和MyBatis整合是非常常见且流行的,可以通过以下步骤进行整合: 1. 添加依赖:在项目的构建文件(如pom.xml)中添加Spring和MyBatis的相关依赖。确保版本兼容性。 2. 配置数据源:在Spring的配置文件(如application.xml)中配置数据源,例如使用连接池(如C3P0、HikariCP)或者直接配置数据库连接。同时,配置MyBatis的一些属性,如Mapper扫描路径等。 3. 配置SessionFactoryBean:使用Spring提供的org.mybatis.spring.SqlSessionFactoryBean配置MyBatis的SqlSessionFactory。可以设置数据源、类型别名、Mapper扫描路径等。 4. 配置MapperScannerConfigurer:使用Spring提供的org.mybatis.spring.mapper.MapperScannerConfigurer配置MyBatis的Mapper扫描路径。可以通过配置basePackage属性设置扫描路径。 5. 编写Mapper接口和Mapper映射文件:创建Mapper接口,并在接口中定义需要的数据库操作方法。然后编写对应的Mapper映射文件,配置SQL语句和结果映射。 6. 注入Mapper接口:在需要使用Mapper接口的地方(如Service层),通过@Autowired或配置文件注入该接口,然后即可调用接口中定义的方法。 7. 开启事务支持:在Service层或需要事务管理的地方,使用Spring提供的@Transactional注解或配置文件声明事务。 以上是简要的整合步骤,具体配置和代码实现可能因项目需求和环境而有所不同。整合完成后,即可在Spring项目中使用MyBatis进行数据库操作,并利用Spring的特性实现更加灵活和便捷的开发。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值