springboot和mybatis的整合(单数据源)

6 篇文章 0 订阅
5 篇文章 0 订阅

springboot和mybatis的整合(单数据源)

​ 本篇使用yaml文件,数据源,mybatis的配置从yaml里直接读取,mapper的数据库操作sql依旧使用xml文件。链接池使用hikari

第一步:pom.xml相关主要依赖
<!-- mybatis整合springboot的jar包 -->
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>1.3.0</version>
</dependency>
<!-- mysql -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <scope>runtime</scope>
</dependency>
<!-- Hikari链接池依赖 -->
<dependency>
    <groupId>com.zaxxer</groupId>
    <artifactId>HikariCP-java7</artifactId>
    <version>2.4.11</version>
</dependency>
第二步:yaml文件

application.yml

spring:
  profiles:
    active: dev

application-dev.yml

server:
  port: 8080
  tomcat:
    uri-encoding: utf-8
    #session超时事件,单位(秒)
  session:
    timeout: 30
logging:
  level:
    root: info
spring:
  datasource:
    url: jdbc:mysql://XXX.XXX.XXX.XXX:3306/cook
    driver-class-name: com.mysql.jdbc.Driver
    username: root
    password: 'XXX'
    hikari:
      maxLifetime: 1765000 #一个连接的生命时长(毫秒),超时而且没被使用则被释放(retired),缺省:30分钟,建议设置比数据库超时时长少30秒以上
      maximumPoolSize: 9 #连接池中允许的最大连接数。缺省值:10;推荐的公式:((core_count * 2) + effective_spindle_count
# 该配置节点为独立的节点,有很多同学容易将这个配置放在spring的节点下,导致配置无法被识别
mybatis:
  mapper-locations: classpath*:/mapping/*Mapper.xml  #注意:一定要对应mapper映射xml文件的所在路径
  type-aliases-package: com.raptor.model  # 注意:对应实体类的路径
  config-location: classpath:mapping/config/mybatis-config.xml

注意:1.因为直接读yaml,datasource的格式,单词不能改动,url必须写url,不能jdbc-url。

​ 2.mybatis的格式单词不能改动,顶格写配置最高层级。

第三步:配置mapper文件
import com.raptor.model.Cooker;
import org.apache.ibatis.annotations.Mapper;
import org.springframework.stereotype.Component;
/**
 * 厨师数据操作
 *
 * @author renhuan
 * @create 2018-09-13 19:51
 */
@Mapper
@Component
public interface CookerMapper {
   void saveNewCooker(Cooker cooker);
}

注意: 1. @Mapper注释写了后,其他地方就可以不用配置@MapperScan

         2. `@Component`写了主要是为了工具在注入mapper的时候不报找不到实例的提示
第四部: mybatis的相关xml文件

cookerMapper.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.raptor.dao.CookerMapper">
  <insert id="saveNewCooker" parameterType="Cooker">
    INSERT INTO t_COOKER (COOKER_NAME,COOKER_AGE) VALUES (#{cookerName},#{cookerAge})
  </insert>
</mapper>

mybatis-config.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
  PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>

  <settings>
    <!-- 驼峰的自动映射 -->
    <setting name="mapUnderscoreToCamelCase" value="true"/>
  </settings>

  <typeAliases>
    <typeAlias alias="Integer" type="java.lang.Integer"/>
    <typeAlias alias="Long" type="java.lang.Long"/>
    <typeAlias alias="HashMap" type="java.util.HashMap"/>
    <typeAlias alias="LinkedHashMap" type="java.util.LinkedHashMap"/>
    <typeAlias alias="ArrayList" type="java.util.ArrayList"/>
    <typeAlias alias="LinkedList" type="java.util.LinkedList"/>
  </typeAliases>
</configuration>

注意: 放置位置和yaml里指定的路径要对应

第五步:省略service和controller,直接junit测试下
import com.raptor.dao.CookerMapper;
import com.raptor.model.Cooker;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
/**
 * Created by Think Pad on 2018/9/13.
 */
@SpringBootTest
@RunWith(SpringJUnit4ClassRunner.class)
public class CookServiceTest {
  @Autowired
  private CookerMapper cookerDao;

  @Test
  public void save(){
    Cooker cooker = new Cooker();
    cooker.setCookerAge(2);
    cooker.setCookerName("zhangsanl");
    cookerDao.saveNewCooker(cooker);
    System.out.println("ok");
  }
}

正常存入数据成功。

单数据源直接在ymal里配置读取,很简洁。如果一个项目需要用到多个数据源的操作,请看:

https://blog.csdn.net/renhuan28/article/details/82729239

装载注明本地址:https://blog.csdn.net/renhuan28/article/details/82734434

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值