springboot整合mybatis

一、jdbc和事务

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

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>

在加入MySQL驱动

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
</dependency>

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

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

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

# 连接参数
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自己实现了:

<!--mybatis -->
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>1.3.2</version>
</dependency>

mybatis需要的配置:

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

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

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

<!-- 通用mapper -->
<dependency>
    <groupId>tk.mybatis</groupId>
    <artifactId>mapper-spring-boot-starter</artifactId>
    <version>2.0.2</version>
</dependency>

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

完整的pom文件如下

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.dwh</groupId>
    <artifactId>spring-test</artifactId>
    <version>1.0-SNAPSHOT</version>

    <!-- 管理jdk版本 -->
    <properties>
        <java.version>1.8</java.version>
    </properties>

    <!-- 依赖父项目 -->
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.0.RELEASE</version>
    </parent>

    <!-- 添加web启动器 -->
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- 需要其他相关启动器,在该节点下添加即可 -->

        <!-- 连接池依赖 -->
        <!--<dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.1.6</version>
        </dependency>-->

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-configuration-processor</artifactId>
            <optional>true</optional>
        </dependency>

        <!-- jdbc启动器 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>

        <!-- mysqll驱动 -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>

        <!--mybatis -->
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>1.3.2</version>
        </dependency>

        <!-- 通用mapper -->
        <dependency>
            <groupId>tk.mybatis</groupId>
            <artifactId>mapper-spring-boot-starter</artifactId>
            <version>2.0.2</version>
        </dependency>
    </dependencies>

</project>

完整的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<User> {
}

创建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<User> 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<User> hello(HttpServletRequest request){
        //该方法只接受get请求
        List<User> user = this.userService.queryAll();
        return user;
    }
}

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

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

项目完整结构:

该节源码如下:

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值