spring中的jdbc连接和事务是配置中的重要一环,在SpringBoot中加入jdbc启动器即可。
org.springframework.boot
spring-boot-starter-jdbc
在加入MySQL驱动
mysql
mysql-connector-java
事务的使用方式跟之前一样,用@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
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;
}
}
启动,调用该测试方法,效果如下测试成功:
注意:博主刚开始测试时,调用selectByPrimaryKey方法时,根据id查询数据,一直查询不到,找了半天,发现原因是因为User实体类中的id没有用@Id注解,标识为主键id,所以导致查询不成功,这个需要大家注意。
项目完整结构:
该节源码如下:
链接:https://pan.baidu.com/s/1SnNFDo74QSbph6F0jH3Q0A 提取码:dejo