前言:
小伙伴们,大家好,我是狂奔の蜗牛rz,当然你们可以叫我蜗牛君,我是一个学习Java半年多时间的小菜鸟,同时还有一个伟大的梦想,那就是有朝一日,成为一个优秀的Java架构师。
这个SpringBoot基础学习系列用来记录我学习SpringBoot框架基础知识的全过程 (这个系列是参照B站狂神的SpringBoot最新教程来写的,由于是之前整理的,但当时没有发布出来,所以有些地方可能有错误,希望大家能够及时指正!)
之后我将会以一天一更的速度更新这个系列,还没有学习SpringBoot的小伙伴可以参照我的博客学习一下;当然学习过的小伙伴,也可以顺便跟我一起复习一下基础。
最后,希望能够和大家一同进步吧!加油吧!少年们!
6.3 整合Mybatis框架 6.3.1 搭建项目基本环境 1.创建Spring Boot项目废话不多说,让我们开始今天的学习内容吧,由于今天我们来到了SpringBoot基础学习的第八站:整合Mybatis框架!
- 创建Spring Initializr项目
- 设置项目基本信息,设置Group、Artifact和Java Vesrion等
- 引入项目资源依赖,Spring Web、JDBC API和MySQL Driver等
- 选择项目存放位置
- 新建项目成功
- 删除多余文件,项目结构如下
- 引入MyBatis资源依赖、
org.mybatis.spring.boot mybatis-spring-boot-starter 2.1.3
- 引入Lombok资源依赖
org.projectlombok lombok 1.16.10
- 引入相关资源依赖后的pom.xml文件
4.0.0 org.springframework.boot spring-boot-starter-parent 2.4.5 com.kuang springboot-05-mybatis 0.0.1-SNAPSHOT springboot-05-mybatis Demo project for Spring Boot 1.8 org.springframework.boot spring-boot-starter-jdbc org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-starter-test test mysql mysql-connector-java runtime 5.1.46 org.mybatis.spring.boot mybatis-spring-boot-starter 2.1.3 org.projectlombok lombok 1.16.10 org.springframework.boot spring-boot-maven-plugin
- 查看项目资源依赖
- 使用properties格式编写配置文件
# 配置数据库相关属性 # 数据库用户登录名 spring.datasource.username=root # 数据库登录密码 spring.datasource.password=123456 # 数据库url连接 spring.datasource.url=jdbc:mysql://localhost:3306/mybatis?useUnicode=true&characterEncoding=utf-8&useSSL=true # 数据库驱动名 spring.datasource.driver-class-name=com.mysql.jdbc.Driver # 配置Tomcat服务器端口号 server.port=8888
- 使用yml格式编写配置文件
# 设置数据库驱动
spring:
datasource:
username: root
password: 123456
url: jdbc:mysql://localhost:3306/mybatis?useUnicode=true&characterEncoding=utf-8&useSSL=true
# com.mysql.jdbc.Driver是8.0以下版本的数据库
driver-class-name: com.mysql.jdbc.Driver
# 设置服务器端口号
server:
port: 8888
3-2 连接MySQL数据库
- 添加数据源,选择MySQL数据库
- 设置数据库登录用户名和密码,进行测试连接
- 选择要连接的具体数据库
- 连接成功,右侧显示数据库表
测试连接过程中遇到了:
解决方法:设置MySQL数据库的时区
1.连接mysqlmysql -u root -p2.查看系统默认的时区
show variables like'%time_zone';3.设置新的时区
set global time_zone = '+8:00';4.查看修改后的时区
这里注意要退出命令窗口后重新进入才可以看到修改成功后的时区
show variables like'%time_zone';4.查看默认数据源和连接
- 修改Springboot的测试类
package com.kuang;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import javax.sql.DataSource;
import java.sql.SQLException;
@SpringBootTest
class Springboot05MybatisApplicationTests {
//将DataSource数据源自动装配到Spring容器中
@Autowired
private DataSource dataSource;
@Test
void contextLoads() throws SQLException {
//打印数据源的类信息
System.out.println(dataSource.getClass());
//打印数据源连接信息
System.out.println(dataSource.getConnection());
}
}
- 查看默认数据源和连接
# 配置数据库相关属性
# 数据库用户登录名
spring.datasource.username=root
# 数据库登录密码
spring.datasource.password=123456
# 数据库url连接
spring.datasource.url=jdbc:mysql://localhost:3306/mybatis?useUnicode=true&characterEncoding=utf-8&useSSL=true
# 数据库驱动名
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
# 配置Tomcat服务器端口号
server.port=8888
# 配置mybatis相关属性
# 通过包设置别名
mybatis.type-aliases-package=com.kuang.pojo
# 设置mapper映射文件的位置
mybatis.mapper-locations=classpath:mybatis/mapper
// @RequestMapping("/getList")
@GetMapping("/getList")
public List getUserList() {
//调用Dao层的getUserList方法,获取所有用户信息列表
List users = userMapper.getUserList();
//遍历用户信息列表
for (User user : users) {
//打印用户信息
System.out.println(user);
}
//返回用户信息列表
return users;
}
@GetMapping("/getUser2")
public User getUserById() {
// 调用Dao层的getUserById方法,通过Id获取指定的用户信息
User user = userMapper.getUserById(1);
// 打印指定的用户信息
System.out.println(user);
// 返回user对象
return user;
}
@GetMapping("/getUser")
public User getUserById2(int id) {
// 调用Dao层的getUserById方法,通过Id获取指定的用户信息
User user = userMapper.getUserById(id);
// 打印指定的用户信息
System.out.println(user);
// 返回user对象
return user;
}
@GetMapping("/getUser/{userId}")
// 使用@PathVariable注解:让方法值对应到URL模板变量上
public User getUserById3(@PathVariable("userId") int id) {
// 调用Dao层的getUserById方法,通过Id获取指定的用户信息
User user = userMapper.getUserById(id);
// 打印指定的用户信息
System.out.println(user);
// 返回user对象
return user;
}
// 增加用户信息
@GetMapping("/addUser")
public String addUser() {
// 获取user对象
User user = new User();
// 设置用户信息
user.setId(6);
user.setName("张碧晨");
user.setPwd("zbc123456");
// 调用Dao层的addUser2方法,添加用户信息
userMapper.addUser(user);
// 返回添加成功字符串
return "addUser-OK";
}
// 通过Id删除用户信息
// 使用@PathVariable注解,将方法变量绑定到URL模板上
@GetMapping("/deleteUser/{userId}")
public String deleteUser(@PathVariable("userId") int id) {
userMapper.deleteUser(id);
return "deleteUser-OK";
}
// 修改用户信息
@GetMapping("/updateUser/{userId}")
// 使用@PathVariable注解,将方法变量绑定到URL模板上
public String updateUser(@PathVariable("userId") int id) {
// 获取user对象
User user = new User();
// 设置用户信息
user.setName("薛之谦");
user.setPwd("xzq123456");
user.setId(id);
// 调用Dao层的updateUser2方法,修改用户信息
userMapper.updateUser(user);
// 返回修改成功字符串
return "updateUser-OK";
}
}
4.增删改查操作和测试结果
4-1 查询所有用户信息
- 页面请求
- 控制台输出
-
页面请求
使用常规风格:
使用RestFul风格:
- 控制台输出
- 页面请求
- 数据库信息
- 页面请求
- 数据库信息
- 页面请求
- 数据库信息
好了,今天的有关 SpringBoot基础学习之整合Mybatis框架 的学习就到此结束啦,欢迎小伙伴们积极学习和讨论,喜欢的可以给蜗牛君点个关注,顺便来个一键三连,我们下期见,拜拜啦!
参考视频链接:https://www.bilibili.com/video/BV1PE411i7CV(【狂神说Java】SpringBoot最新教程IDEA版通俗易懂)



