spring boot 学习(五)SpringBoot+MyBatis(XML)+Druid

SpringBoot+MyBatis(xml)+Druid

前言

springboot集成了springJDBC与JPA,但是没有集成mybatis,所以想要使用mybatis就要自己去集成。
主要是在Spring Boot中集成MyBatis,可以选用基于注解的方式,也可以选择xml文件配置的方式。官方推荐使用xml文件配置。

springboot+mybatis+druid

1. 引入依赖

        
        <dependency>
            <groupId>org.mybatis.spring.bootgroupId>
            <artifactId>mybatis-spring-boot-starterartifactId>
            <version>1.1.1version>
            
        dependency>
        
        <dependency>
            <groupId>com.alibabagroupId>
            <artifactId>druidartifactId>
            <version>1.0.20version>
        dependency>
        
        <dependency>
            <groupId> mysqlgroupId>
            <artifactId> mysql-connector-javaartifactId>
            <version> 5.0.5version>
        dependency>

2. 在Mysql中创建Users表

Users表中包含id(BIGINT)、name(INT)、age(VARCHAR)字段。

3. 创建接口Mapper(不是类)和对应的XML文件

User实体类:

public class User {

    private long id;
    private String name;
    private Integer age;

    // 省略相应的 getter 与 setter 方法
}

UserDao接口:实现插入和查询操作
注意必须加上@Mapper的注解,不然@Autowired将注入失败。

@Mapper
public interface UserDao{

    int insertUser(@Param("user") User user);

    User findByName(String name);
}

@Mapper注解标记这个接口作为一个映射接口。真正实现映射的方法(XML文件)需要源对象作为参数,并返回目标对象。
UserMapper.xml文件:



<mapper namespace="qg.fangrui.boot.dao.UserDao">
    

    
    <resultMap id="UserResultMap" type="qg.fangrui.boot.model.User">
        <id property="id" column="id" />
        <result property="name" column="name" />
        <result property="age" column="age" />
    resultMap>

    <insert id="insertUser" >
        INSERT INTO users(name, age)
        VALUES (#{user.name}, #{user.age})
    insert>

    <select id="findByName" resultType="User">
        SELECT * FROM users WHERE name = #{name}
    select>

mapper>

4. 配置文件

application.properties:

# 驱动配置信息
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.url = jdbc:mysql://127.0.0.1:3306/myboot?useUnicode=true&characterEncoding=utf-8
spring.datasource.username = root
spring.datasource.password = 123456
spring.datasource.driverClassName = com.mysql.jdbc.Driver

#连接池的配置信息
spring.datasource.initialSize=5
spring.datasource.minIdle=5
spring.datasource.maxActive=20
spring.datasource.maxWait=60000
spring.datasource.timeBetweenEvictionRunsMillis=60000
spring.datasource.minEvictableIdleTimeMillis=300000
spring.datasource.validationQuery=SELECT 1 FROM DUAL
spring.datasource.testWhileIdle=true
spring.datasource.testOnBorrow=false
spring.datasource.testOnReturn=false
spring.datasource.poolPreparedStatements=true
spring.datasource.maxPoolPreparedStatementPerConnectionSize=20
spring.datasource.filters=stat,wall,log4j
spring.datasource.connectionProperties=druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000

# MyBatis 配置
mybatis.mapper-locations=classpath:mapper/*.xml
mybatis.type-aliases-package=qg.fangrui.boot.model

5. 调用测试:

一般情况下,我是用Controller层调用Service层,Service层调用Dao层。测试案例比较简单,我就不列了,只是简单展示一下相应的Controller。

@RestController
@RequestMapping("/test")
public class TestController {

    @Autowired
    private UserService userService;

    @RequestMapping("/add")
    public String add(User user){
        return String.valueOf(userService.add(user));
    }

}

效果图:
Postman测试图:
spring boot 学习(五)SpringBoot+MyBatis(XML)+Druid_第1张图片
Druid监控图:
spring boot 学习(五)SpringBoot+MyBatis(XML)+Druid_第2张图片

附录

补充

mybatis-spring-boot-starter的依赖树:
spring boot 学习(五)SpringBoot+MyBatis(XML)+Druid_第3张图片

Mybatis 在 SpringBoot 中的配置:
* mybatis.mapper-locations:xml文件扫描位置
* mybatis.type-aliases-package:Model包扫描位置
* mybatis.config:mybatis-config.xml配置文件的路径
* mybatis.typeHandlersPackage:扫描typeHandlers的包
* mybatis.checkConfigLocation:检查配置文件是否存在
* mybatis.executorType:设置执行模式(SIMPLE, REUSE, BATCH),默认为SIMPLE

项目参考

集合了我的 SpringBoot 学习的案例:
包括了我前面学习的案例!
SpringBoot+MyBatis+Druid

参考资料

  • (官方文档,推荐)http://www.mybatis.org/spring-boot-starter/mybatis-spring-boot-autoconfigure/
  • (超级大神)http://blog.csdn.net/isea533/article/details/50359390?locationNum=3&fps=1
  • (注解类MyBatis)http://blog.didispace.com/springbootmybatis/

你可能感兴趣的:(spring,boot)