springboot整合mybatis

一、jdbc和事务

spring中的jdbc连接和事务是配置中的重要一环,在SpringBoot中加入jdbc启动器即可。


    org.springframework.boot
    spring-boot-starter-jdbc

在加入MySQL驱动


    mysql
    mysql-connector-java

事务的使用方式跟之前一样,用@Transactional注解

接着整合连接池,刚才引入jdbc启动器的时候,SpringBoot已经自动帮我们引入了一个连接池,叫光,号称目前速度最快的连接池。经过测试也确实是这样。查看项目的依赖,找到光,就是下图这个

springboot整合mybatis_第1张图片

我们在全局配置文件中配置光的需要的连接参数

# 连接参数
spring.datasource.url=jdbc:mysql://localhost:3306/ssm?useSSL=true
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driverClassName=com.mysql.jdbc.Driver

spring.datasource.hikari.idle-timeout=60000
spring.datasource.hikari.maximum-pool-size=30
spring.datasource.hikari.minimum-idle=10

整合mybatis

SpringBoot官方并没有提供Mybatis的启动器,不过Mybatis自己实现了:



    org.mybatis.spring.boot
    mybatis-spring-boot-starter
    1.3.2

mybatis需要的配置:

# mybatis 别名扫描
mybatis.type-aliases-package=com.springboot.entity
# mapper.xml文件位置,如果没有映射文件,注释掉
#mybatis.mapper-locations=classpath:mappers/*.xml

好,mybatis的配置就这么多,这里我们接着加入 通用mapper ,便捷我们的开发,不知道通用mapper是干什么的可以百度一下。

通用Mapper的作者也为自己的插件编写了启动器,我们直接引入即可:



    tk.mybatis
    mapper-spring-boot-starter
    2.0.2

好的,到这里就全部配置完了,我们后面就创建实体类,mapper接口等来进行测试,不过需要特别注意的是,之前项目讲解springboot java注入的时候,用过阿里巴巴的连接池,因为我们这里已经用了光,所以之前对于阿里巴巴连接池的依赖以及Java配置都要删除或者注释掉,否者会报错。

完整的pom文件如下



    4.0.0

    com.dwh
    spring-test
    1.0-SNAPSHOT

    
    
        1.8
    

    
    
        org.springframework.boot
        spring-boot-starter-parent
        2.0.0.RELEASE
    

    
    
        
            org.springframework.boot
            spring-boot-starter-web
        
        

        
        

        
            org.springframework.boot
            spring-boot-configuration-processor
            true
        

        
        
            org.springframework.boot
            spring-boot-starter-jdbc
        

        
        
            mysql
            mysql-connector-java
        

        
        
            org.mybatis.spring.boot
            mybatis-spring-boot-starter
            1.3.2
        

        
        
            tk.mybatis
            mapper-spring-boot-starter
            2.0.2
        
    

完整的application.properties文件如下,注意更改为自己的数据库名字以及账号密码:

# 映射端口
server.port=8080

# 连接四大参数
spring.datasource.url=jdbc:mysql://localhost:3306/ssm?useSSL=true
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driverClassName=com.mysql.jdbc.Driver
spring.datasource.hikari.idle-timeout=60000
spring.datasource.hikari.maximum-pool-size=30
spring.datasource.hikari.minimum-idle=10

# mybatis 别名扫描
mybatis.type-aliases-package=com.springboot.entity
# mapper.xml文件位置,如果没有映射文件,请注释掉
#mybatis.mapper-locations=classpath:mappers/*.xml

三、测试

创建User类,跟数据库表对应,放在entity包下:

package com.springboot.entity;

public class User {
    private String id;

    private String username;

    private String password;

    private String company;

    private Integer age;

    private Integer sex;

    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id == null ? null : id.trim();
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username == null ? null : username.trim();
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password == null ? null : password.trim();
    }

    public String getCompany() {
        return company;
    }

    public void setCompany(String company) {
        this.company = company == null ? null : company.trim();
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    public Integer getSex() {
        return sex;
    }

    public void setSex(Integer sex) {
        this.sex = sex;
    }
}

创建mapper接口,继承通用Mapper,注意要加@Mapper注解,让他被扫描到,该类放在mapper包下:

package com.springboot.mapper;

import com.springboot.entity.User;
import tk.mybatis.mapper.common.Mapper;

@org.apache.ibatis.annotations.Mapper
public interface UserMapper extends Mapper {
}

创建UserService,放在service包下

package com.springboot.service;

import com.springboot.entity.User;
import com.springboot.mapper.UserMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;

import java.util.List;

@Service
public class UserService {

    @Autowired
    private UserMapper userMapper;

    public User queryById(String id){
        return this.userMapper.selectByPrimaryKey(id);
    }

    @Transactional
    public void deleteById(String id){
        this.userMapper.deleteByPrimaryKey(id);
    }

    public List queryAll() {
        return this.userMapper.selectAll();
    }
}

继承通用mapper后,给我提供了单表的增删改查等功能,直接调用即可,极大的节省了我们的开发效率。

改一下之前的测试类,调用查询方法看看mybatis是否整合成功

package com.springboot.controller;

import com.springboot.entity.User;
import com.springboot.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.servlet.http.HttpServletRequest;
import java.util.List;

@RestController
public class TestController {
    //@RestController注解相当于@ResponseBody + @Controller合在一起的作用。

    @Autowired
    private UserService userService;

    //@GetMapping是一个组合注解,是@RequestMapping(method = RequestMethod.GET)的缩写。该注解将HTTP Get 映射到 特定的处理方法上。
    @GetMapping("hello")
    public  List hello(HttpServletRequest request){
        //该方法只接受get请求
        List user = this.userService.queryAll();
        return user;
    }
}

启动,调用该测试方法,效果如下测试成功:

springboot整合mybatis_第2张图片

注意:博主刚开始测试时,调用selectByPrimaryKey方法时,根据id查询数据,一直查询不到,找了半天,发现原因是因为User实体类中的id没有用@Id注解,标识为主键id,所以导致查询不成功,这个需要大家注意。

项目完整结构:

springboot整合mybatis_第3张图片

该节源码如下:

链接:https://pan.baidu.com/s/1SnNFDo74QSbph6F0jH3Q0A       提取码:dejo 
 

你可能感兴趣的:(Java)