栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

SpringBoot基础学习之整合Mybatis框架

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

SpringBoot基础学习之整合Mybatis框架

前言:

小伙伴们,大家好,我是狂奔の蜗牛rz,当然你们可以叫我蜗牛君,我是一个学习Java半年多时间的小菜鸟,同时还有一个伟大的梦想,那就是有朝一日,成为一个优秀的Java架构师。
这个SpringBoot基础学习系列用来记录我学习SpringBoot框架基础知识的全过程 (这个系列是参照B站狂神的SpringBoot最新教程来写的,由于是之前整理的,但当时没有发布出来,所以有些地方可能有错误,希望大家能够及时指正!)
之后我将会以一天一更的速度更新这个系列,还没有学习SpringBoot的小伙伴可以参照我的博客学习一下;当然学习过的小伙伴,也可以顺便跟我一起复习一下基础。
最后,希望能够和大家一同进步吧!加油吧!少年们!

废话不多说,让我们开始今天的学习内容吧,由于今天我们来到了SpringBoot基础学习的第八站:整合Mybatis框架

6.3 整合Mybatis框架 6.3.1 搭建项目基本环境 1.创建Spring Boot项目
  • 创建Spring Initializr项目

  • 设置项目基本信息,设置Group、Artifact和Java Vesrion等

  • 引入项目资源依赖,Spring Web、JDBC API和MySQL Driver等

  • 选择项目存放位置

  • 新建项目成功

  • 删除多余文件,项目结构如下

2.引入Mybatis和Lombok资源依赖
  • 引入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
            
        
    


  • 查看项目资源依赖

3.连接MySQL数据库 3-1 编写applicationContext核心配置文件
  • 使用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数据库

  • 设置数据库登录用户名和密码,进行测试连接

  • 选择要连接的具体数据库

  • 连接成功,右侧显示数据库表

3-3 数据库连接失败解决方案

测试连接过程中遇到了:

解决方法设置MySQL数据库的时区

1.连接mysql
mysql  -u root -p

2.查看系统默认的时区
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());
    }

}
  • 查看默认数据源和连接

6.3.2 完善项目基本环境 1.项目基本结构和修改配置文件 1-1 项目基本结构

1-2 修改核心配置文件
# 配置数据库相关属性
# 数据库用户登录名
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 查询所有用户信息
  • 页面请求

  • 控制台输出

4-2 通过Id查询指定用户信息
  • 页面请求

    使用常规风格:

    使用RestFul风格:

  • 控制台输出

4-3 增加用户信息
  • 页面请求

  • 数据库信息

4-4 删除用户信息
  • 页面请求

  • 数据库信息

4-5 修改用户信息
  • 页面请求

  • 数据库信息

好了,今天的有关 SpringBoot基础学习之整合Mybatis框架 的学习就到此结束啦,欢迎小伙伴们积极学习和讨论,喜欢的可以给蜗牛君点个关注,顺便来个一键三连,我们下期见,拜拜啦!


参考视频链接:https://www.bilibili.com/video/BV1PE411i7CV(【狂神说Java】SpringBoot最新教程IDEA版通俗易懂)

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/336808.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号