SpringBoot整合MyBatis

1、创建项目时勾选mybatis、数据库驱动。

 

mysql驱动默认是8.x的版本,如果要使用5.x的版本,创建后到pom.xml中改。

也可以手动添加依赖

<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.1.2</version> <!-- 这个必须要版本号 -->
</dependency> <dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<!-- 默认是8.x的版本,可以自己加<version>指定版本 -->
<scope>runtime</scope>
</dependency>

  

2、新建包model,存放实体类

@Getter
@Setter
@ToString
public class User {
private int id;
private String name;
//......
}

  

实体类不需要放到spring容器中

3、新建包dao,存放mapper接口

public interface UserMapper{
public User findUserById(Integer id);
}

  

mapper接口上不需要加注解

4、resources下新建文件夹mapper,存放mybatis的xml映射文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.chy.mall.dao.UserMapper"> <select id="findUserById" parameterType="integer" resultType="user">
select * from tb_user where id=#{id}
</select> </mapper>

  

5、引导类上加@MapperScan

@MapperScan("com.chy.mall.dao")  //指定mapper接口位置

// @MapperScan( { "com.chy.mall.dao1" , "com.chy.mall.dao2" } )  //有多个包时写成数组

  

注意是@MapperScan,不是@MapperScans,末尾没有s。
也可以在每个mapper接口上标注@Mapper,但是很麻烦。

6、application.properties中添加mybatis的配置

###mybatis配置###
#配置实体类的别名
mybatis.type-aliases-package=com.chy.mall.model
#指定映射文件的位置
mybatis.mapper-locations=classpath:mapper/*Mapper.xml

  

HiKari的使用

c3p0、dbcp老旧、性能低下,hikari、druid后起之秀,性能方面hikari、druid独一档。
性能:hikari > druid > tomcat-jdbc > dbcp > c3p0

HiKariCP,CP是Connection Pool的简写,号称性能最高的连接池。代码经过精简优化,体积很小,稳定可靠、性能极高。hikari的高性能得益于最大限度地避免锁竞争。

druid是阿里开源的连接池,性能略有不如hikari,但功能全面、扩展性强,对数据库操作有监控、统计功能,便于分析、优化数据库操作。

springboot 2.x默认使用hikari作为数据库连接池,不需要添加额外依赖,只需在application.properties中配置即可。

hikari常用配置如下

###数据源配置###

#默认就是hikari,可缺省
#spring.datasource.type=com.zaxxer.hikari.HikariDataSource spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/db_mall?serverTimezone=UTC
spring.datasource.username=chy
spring.datasource.password=abcd #默认30000ms,即30s
#spring.datasource.hikari.connection-timeout=30000
#默认600000ms,即10min
#spring.datasource.hikari.idle-timeout=600000 #连接池的最大尺寸(闲置连接+正在使用的连接),默认10
spring.datasource.hikari.maximum-pool-size=200
#最小空闲连接数,默认10
spring.datasource.hikari.minimum-idle=50

  

Druid的使用

1、添加druid的依赖

<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.1.22</version>
</dependency> <!-- 也可以使用下面这个 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.22</version>
</dependency>

  

2、application.properties

###数据源配置###

#指定数据源类型为druid
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/db_mall?serverTimezone=UTC
spring.datasource.username=chy
spring.datasource.password=abcd #初始连接数,默认0
spring.datasource.druid.initial-size=50
#最小空闲连接数
spring.datasource.druid.min-idle=30
#最大活跃连接数,默认8
spring.datasource.druid.max-active=200
#以上3个配置项,设置为0表示无限 #获取连接的最大等待时间(池中无空闲连接时最多等待多少ms),默认-1 一直等待,此处设置为30000ms,即30s
spring.datasource.druid.max-wait=30000 #是否缓存PreparedStatement,默认false
#spring.datasource.druid.poolPreparedStatements=true
#缓存的PreparedStatement的最大数量,默认-1 不缓存,大于0时会自动开启PreparedStatement缓存,所以可以缺省上一句配置
spring.datasource.druid.maxOpenPreparedStatements=20

  

连接池配置说明

上面的配置,不管是hikari还是druid,都没有使用自己的key来配置数据库驱动、url、username、password,使用自己的key要报错。即不要使用下面的key

#hikari
spring.datasource.hikari.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.hikari.jdbc-url=jdbc:mysql://localhost:3306/db_mall?serverTimezone=UTC
spring.datasource.hikari.username=chy
spring.datasource.hikari.password=abcd #druid
spring.datasource.druid.driver-class-name=jdbc:mysql://127.0.0.1/db_mall?serverTimezone=UTC
spring.datasource.druid.url=com.mysql.cj.jdbc.Driver
spring.datasource.druid.username=chy
spring.datasource.druid.password=abcd

  

大家看完有什么不懂的欢迎在下方留言评论

SpringBoot整合MyBatis,HiKari、Druid连接池的使用的更多相关文章

  1. (二)SpringBoot整合常用框架Druid连接池

    一,在Pom.xml文件加入依赖 找到<dependencies></dependencies>标签,在标签中添加Druid依赖 <dependency> < ...

  2. SpringBoot 整合mongoDB并自定义连接池

    SpringBoot 整合mongoDB并自定义连接池 得力于SpringBoot的特性,整合mongoDB是很容易的,我们整合mongoDB的目的就是想用它给我们提供的mongoTemplate,它 ...

  3. Spring整合JDBC和Druid连接池

    我的博客名为黑客之谜,喜欢我的,或者喜欢未来的大神,点一波关注吧!顺便说一下,双十二快到了,祝大家双十二快乐,尽情的买买买~ 如果转载我的文章请标明出处和著名,谢谢配合. 我的博客地址为: https ...

  4. SpringMVC+Spring+Mybatis整合,使用druid连接池,声明式事务,maven配置

    一直对springmvc和mybatis挺怀念的,最近想自己再搭建下框架,然后写点什么. 暂时没有整合缓存,druid也没有做ip地址的过滤.Spring的AOP简单配置了下,也还没具体弄,不知道能不 ...

  5. SpringBoot整合自定义FTP文件连接池

    说明:通过GenericObjectPool实现的FTP连接池,记录一下以供以后使用环境:JDK版本1.8框架 :springboot2.1文件服务器: Serv-U1.引入依赖 <!--ftp ...

  6. springboot整合druid连接池、mybatis实现多数据源动态切换

    demo环境: JDK 1.8 ,Spring boot 1.5.14 一 整合durid 1.添加druid连接池maven依赖 <dependency> <groupId> ...

  7. SpringBoot入门篇--整合mybatis+generator自动生成代码+druid连接池+PageHelper分页插件

    原文链接 我们这一篇博客讲的是如何整合Springboot和Mybatis框架,然后使用generator自动生成mapper,pojo等文件.然后再使用阿里巴巴提供的开源连接池druid,这个连接池 ...

  8. MyBatis学习-使用Druid连接池将Maybatis整合到spring

    目录 前言 什么是Druid连接池 Druid可以做什么? 导入库包 连接oracle 连接mysql 导入mybatis 导入druid 导入spring-jdbc包 导入spring包 导入spr ...

  9. spring 5.x 系列第6篇 —— 整合 mybatis + druid 连接池 (代码配置方式)

    源码Gitub地址:https://github.com/heibaiying/spring-samples-for-all 项目目录结构 1.创建maven工程,除了Spring基本依赖外,还需要导 ...

随机推荐

  1. 逻辑运算 - js笔记

    && 与 || undefined null NaN "" 0 => false 在 && 中,当第一个值为false停止运行,返回该值,即遇 ...

  2. chrome浏览器中调试窗口位置修改

    在这里修改就好了

  3. 循序渐进VUE+Element 前端应用开发(21)--- 省市区县联动处理的组件使用

    在很多应用中,往往都涉及到记录用户所在省份.城市.区县或者街道等信息,一般我们可以通过联动的Select或者类似的界面组件进行展示,或者使用Element中的el-cascader界面组件进行展示,而 ...

  4. 通过两行代码即可调整苹果电脑 Launchpad 图标大小

    之前用 13 寸 Mac 的时候我还没觉得,后来换了 16 寸就发现有点不对劲了.因为 Mac 的高分辨率,当你进入 Launchpad 界面,应用图标的大小可能会让你怀疑:这特么是苹果的设计吗?有点 ...

  5. sql布尔盲注和时间盲注的二分脚本

    布尔盲注: import requests url = "http://challenge-f0b629835417963e.sandbox.ctfhub.com:10080/" ...

  6. dubbo-高可用-负载均衡配置

    在集群负载均衡时,Dubbo 提供了多种均衡策略,缺省为 random 随机调用. 负载均衡策略 1.Random LoadBalance随机,按权重设置随机概率.在一个截面上碰撞的概率高,但调用量越 ...

  7. Spring入门-------------1

    Spring是一个开源框架,为简化企业级应用开发而生,使用Spring可以使简单的JavaBean 实现以前只有EJB才能实现的功能.Spring 是一个IOC和Aop容器框架. 特性: 轻量级:Sp ...

  8. EBAZ4205学习资源整理

    EBAZ4205是一块矿机的控制板,芯片是ZYNQ7010,某鱼上应该不超过30元就能买一块,垃圾佬狂喜 经过不复杂的操作就能进行正常开发,由于货量比较大现在已经有很多大佬写了很多很多好的资料,这里我 ...

  9. git rebase的时候捅娄子了,怎么办?在线等……

    大家在使用git的过程当中有闯过祸吗? 我闯过,我闯的第一个祸就是使用git rebase造成的,虽然后来最终还是解决了,但是还是给我吓得不轻.当时的事情是这样的. 我们来看下这张图: 简单解释一下这 ...

  10. Java 将JSON反射到实体类

    通过服务间调用拿到的数据返回的格式是JSON,如果你当前这个服务有实体数据类型可以对应上,那么就可以轻松愉快的搞定. 如果数据格式对不上,例如这个JSON里面有些数据是我们不想要的,这样我们实体的数据 ...