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