DAY07_SpringBoot—用法整合MyBatis

news2024/12/24 7:46:32

目录

  • 1 SpringBoot 用法
    • 1.1 环境切换
      • 1.1.1 业务需求
      • 1.1.2 多环境编辑
    • 1.2 热部署
      • 1.2.1 需求说明
      • 1.2.2 引入jar包
      • 1.2.3 配置IDEA环境
  • 2 SpringBoot整合Mybatis
    • 2.1 导入数据库
    • 2.2 创建SpringBoot项目
      • 2.2.1 创建项目
      • 2.2.2 生成POM.xml文件如下
      • 2.2.3 Mavenjar包作用范围
      • 2.2.4 数据源配置
      • 2.2.5 Mybatis相关配置
      • 2.2.6 编辑Mapper接口/映射文件
      • 2.2.7 将Mapper接口交给容器管理
      • 2.2.8 Mybatis测试
    • 2.3 关于绑定异常
      • 2.3.1 报错说明
      • 2.3.2 关于数据库密码问题
    • 2.4 关于Mapper接口代理对象创建流程
    • 2.5 Mybatis入库练习
      • 2.5.1 编辑Mapper接口
      • 2.5.2 编辑Mapper.xml 文件
      • 2.5.3 业务调用
    • 2.6 Mybatis更新练习
      • 2.6.1 Mapper接口
      • 2.6.2 编辑Mapper.xml映射文件
      • 2.6.3 编辑测试类

1 SpringBoot 用法

1.1 环境切换

1.1.1 业务需求

软件一般会在多个不同的环境中运行. 开发阶段有一个dev环境.开发完成会进行测试.则会有测试环境.最终项目部署到用户的服务中会有生产环境

如果每次切换环境,如果都需要手动的修改配置文件,则造成诸多的不便

1.1.2 多环境编辑

如果采用多环境测试,则要求每个环境中的数据项都应该保持一致. 否则缺失可能导致项目启动异常.
多环境配置关键语法"- - -" 环境分割

定义环境名称:

#默认环境选项
spring:
  profiles:
    #默认环境配置名称
    active: test

#环境分割
---
#YML文件语法
## 1.YML数据结构k-v结构
## 2.k与v 需要使用 :"空格" 连接
## 3.YMl配置文件有父子级关系 所以注意缩进项的位置
spring:
  config:
    activate:
      on-profile: prod
server:
  port: 80    #配置端口
  servlet:      #web项目发布路径
    context-path: /  #/表示根目录

#定义dept属性值 YML文件默认支持UTF-8
dept:
  id: 100
  name: 财务部

#环境分割线
---

# 每个环境都应该有自己的名称
spring:
  config:
    activate:
      on-profile: test
server:
  port: 8080    #配置端口
  servlet:      #web项目发布路径
    context-path: /  #/表示根目录

#定义dept属性值 YML文件默认支持UTF-8
dept:
  id: 100
  name: 集团本部

1.2 热部署

1.2.1 需求说明

在开发阶段每次修改完源码都要重启服务器,程序才能生效. 能否让程序自动的完成监控,重启服务器.

1.2.2 引入jar包

<!--支持热部署 -->
<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-devtools</artifactId>
</dependency>

1.2.3 配置IDEA环境

  • 勾选自动编译
    • 组合键: ctrl + shift + alt + / 或者 ctrl + alt + a

在这里插入图片描述
在这里插入图片描述

  • 或者通过如下方式进行设置自动编译

在这里插入图片描述

  • 启动IDEA自动编译

在这里插入图片描述

2 SpringBoot整合Mybatis

2.1 导入数据库

  • 新建数据库

在这里插入图片描述

  • 导入数据

在这里插入图片描述

2.2 创建SpringBoot项目

2.2.1 创建项目

在这里插入图片描述
在这里插入图片描述

2.2.2 生成POM.xml文件如下

<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>3.2.2</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.jt</groupId>
    <artifactId>springboot_demo_2</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>springboot_demo_2</name>
    <description>springboot_demo_2</description>
    <properties>
        <java.version>17</java.version>
    </properties>
    <dependencies>
        <!--spring-boot-starter 启动项  只要导入jar包 则可以完成自动的配置  暂时没有数据库的链接所以报错-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>3.0.3</version>
        </dependency>
        <!--引入数据库驱动 -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.20</version>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter-test</artifactId>
            <version>3.0.3</version>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <excludes>
                        <exclude>
                            <groupId>org.projectlombok</groupId>
                            <artifactId>lombok</artifactId>
                        </exclude>
                    </excludes>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>

2.2.3 Mavenjar包作用范围

  • test范围是指测试范围有效,在编译和打包时都不会使用这个依赖
  • compile范围是指编译范围内有效,在编译和打包时都会将依赖存储进去
  • provided依赖,在编译和测试过程中有效,最后生成的war包时不会加入
    • 例如servlet-api,因为servlet-api tomcat服务器已经存在了,如果再打包会冲突
  • runtime在运行时候依赖,在编译时候不依赖
  • 默认依赖范围是compile

2.2.4 数据源配置

#SpringBoot 开箱即用
spring:
  datasource:
    url: jdbc:mysql://127.0.0.1:3306/jtadmin?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf8&autoReconnect=true&allowMultiQueries=true
    username: root
    password: root

很多写法好用即可

spring:
  datasource:
    url: jdbc:mysql://127.0.0.1:3306/jtadmin?useSSL=false&serverTimezone=Asia/Shanghai&characterEncoding=utf8
    username: root
    password: root
  • serverTimezone=GMT%2B8
    • %2B “+” 号 新版本的驱动要求必须配置时区
    • serverTimezone=Asia/Shanghai
  • &useUnicode=true&characterEncoding=utf8
    • 使用Unicode编码 要求字符UTF-8编码
    • &characterEncoding=utf8
  • &autoReconnect=true
    • 是否自动重连.
  • &allowMultiQueries=true
    • 是否允许批量操作 同时执行多个sql!
  • useSSL=false
    • 是否进行安全认证

2.2.5 Mybatis相关配置

#SpringBoot整合Mybatis配置
mybatis:
  #定义别名包
  type-aliases-package: com.jt.pojo
  mapper-locations: classpath:/mybatis/mappers/*.xml
  #开启驼峰映射
  configuration:
    map-underscore-to-camel-case: true

2.2.6 编辑Mapper接口/映射文件

在这里插入图片描述

import com.jt.pojo.DemoUser;

import java.util.List;
public interface DemoUserMapper {
    List<DemoUser> findAll();
}
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--namespace
	1.Mapper.xml配置文件的唯一标识
	2.需要与Mapper接口保持一致.
	  UserMapper.findAll();  通过方法映射Sql语句!!!
-->
<mapper namespace="com.jt.mapper.DemoUserMapper">
    <!--查询标签必须有返回值
        resultType :直接返回POJO对象的数据  单表查询
        resultMap: 适用于关联查询的结果封装 一般采用第三方对象接收

        问题:能否将不变的包路径进行优化???
        解决方案: 定义别名包即可
        说明:
            resultType="包名.类名"  resultType="com.jt.pojo.DemoUser"
        定义别名包
        type-aliases-package: com.jt.pojo
        resultType="DemoUser" 可以直接返回对象的名称
        程序解析时: 首先根据别名包的名称进路径的拼接 com.jt.pojo.DemoUser
    -->
    <select id="findAll" resultType="DemoUser">
        select * from demo_user
    </select>
</mapper>

2.2.7 将Mapper接口交给容器管理

在这里插入图片描述

2.2.8 Mybatis测试

编辑测试类,注意包路径的写法.

@SpringBootTest
public class TestSpringBoot {
    @Autowired
    private DemoUserMapper userMapper;

    @Test
    public void testFindAll(){
        System.out.println(userMapper.findAll());
    }
}

2.3 关于绑定异常

2.3.1 报错说明

绑定异常: mapper的接口与xml的映射文件之间绑定异常.

org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.jt.mapper.DemoUserMapper.findAll

代码排查:

1).检查Mapper接口的路径

在这里插入图片描述

2).检查mapper.xml引入过程

在这里插入图片描述

3).检查mapper.xml映射文件

在这里插入图片描述

4).检查方法名称
检查mapper接口方法名称,与标签的ID是否一致.

在这里插入图片描述

5). 清空/重新编译项目

1).clean项目
在这里插入图片描述
2).build项目
在这里插入图片描述

6).检查目录层级,是否使用/进行分割.

2.3.2 关于数据库密码问题

我们创建数据库时账号密码一般都是 root/root

如果创建数据库密码时 以数字0开头 012345

数据密码在进行编译时. 如果遇到首字母为0则自动删除

如果以特殊数字开头 则 “012345” 引号包裹

2.4 关于Mapper接口代理对象创建流程

说明: 当springBoot启动时,加载pom.xml文件.实例化对象的流程图

在这里插入图片描述

2.5 Mybatis入库练习

2.5.1 编辑Mapper接口

在这里插入图片描述

2.5.2 编辑Mapper.xml 文件

<!--
	完成用户入库操作 id="与方法名称保持一致"
	sql结束时不需要添加;号 在Mysql数据库中执行;号没有问题,
	但是如果在Oracle中执行则必然报错.
-->
<insert id="insertUser">
	insert into demo_user(id,name,age,sex) values(null,#{name},#{age},#{sex})
</insert>

2.5.3 业务调用

 //新增用户
@Test
public void testInsert(){
	DemoUser user = new DemoUser();
	user.setId(null).setName("mybatis信息").setAge(18).setSex("男");
	userMapper.insertUser(user);
}

2.6 Mybatis更新练习

2.6.1 Mapper接口

在这里插入图片描述

2.6.2 编辑Mapper.xml映射文件

在mapper.xml文件中 实现更新操作

<!--编辑更新操作  #mybatis中的一种表达式写法 -->
<update id="updateUser">
	update demo_user set name=#{nowName} where name=#{oldName} and sex=#{sex}
</update>

2.6.3 编辑测试类

@Test
public void testUpdate(){
    //1.封装数据
    String oldName = "mybatis信息";
    String nowname = "测试信息";
    String sex = "男";
    userMapper.updateUser(oldName,nowname,sex);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1404943.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

面试经验分享 | 工控安全研究员

本文由掌控安全学院 - 徐浩洋 投稿 笔试 进程注入有几种简单描述一下? Windows异常分发流程。 Windows下反调试和反反调试的手段。 使用分页机制下虚拟地址怎么翻译为物理地址。 符号延时加载(DeferredSymbolLoading)的原理? 漏洞触发流程是怎么样的,怎么定位触发点如何进行…

服务器数据恢复—服务器进水导致阵列中磁盘同时掉线的数据恢复案例

服务器数据恢复环境&#xff1a; 数台服务器数台存储阵列柜&#xff0c;共上百块硬盘&#xff0c;划分了数十组lun。 服务器故障&检测&#xff1a; 外部因素导致服务器进水&#xff0c;进水服务器中一组阵列内的所有硬盘同时掉线。 北亚数据恢复工程师到达现场后发现机房内…

OpenMP和MPI环境配置

目录 OpenMP和MPI环境配置OpenMP环境配置MPI环境配置&#xff08;Windows&#xff09;MPI环境配置&#xff08;Ubuntu&#xff09; 参考资料 OpenMP和MPI环境配置 OpenMP环境配置 首先创建项目&#xff0c;选择C 控制台应用。 选择项目&#xff0c;属性。 在C/C —— 语言中&…

老师家访的目的是什么

家访&#xff0c;对于老师来说&#xff0c;是工作中必不可少的一部分。有人会问&#xff0c;老师家访的目的是什么呢&#xff1f;是为了了解学生的家庭情况&#xff0c;还是为了和家长建立良好的沟通关系&#xff1f;其实&#xff0c;老师家访的目的远不止于此。 老师家访是为…

【MySQL】计算日期是当前月份的第几周

力扣题 1、题目地址 2993. 发生在周五的交易 I 2、模拟表 表&#xff1a;Purchases Column NameTypeuser_idintpurchase_datedateamount_spendint (user_id, purchase_date, amount_spend) 是该表的主键(具有唯一值的列)。purchase_date 的范围从 2023 年 11 月 1 日到 2…

对称图做法,全程动图演示

最终效果&#xff1a; 实现步骤&#xff1a; 其他图形画法&#xff1a; 点线对比图做法&#xff0c;全程动图演示 气泡图做法&#xff0c;全程动图演示 重叠柱状图做法&#xff0c;全程动图演示 瀑布图做法&#xff0c;全程动图演示 对称图做法&#xff0c;全程动图演示

轻松上手:通过阿里云PAI QuickStart微调部署Qwen-72B-Chat模型

作者&#xff1a;熊兮、求伯、一耘 引言 通义千问-72B&#xff08;Qwen-72B&#xff09;是阿里云研发的通义千问大模型系列的720亿参数规模模型。Qwen-72B的预训练数据类型多样、覆盖广泛&#xff0c;包括大量网络文本、专业书籍、代码等。Qwen-72B-Chat是在Qwen-72B的基础上…

第一篇【传奇开心果系列】beeware的toga开发移动应用:轮盘抽奖移动应用

系列博文目录 beeware的toga开发移动应用示例系列博文目录一、项目目标二、开发传奇开心果轮盘抽奖安卓应用编程思路三、传奇开心果轮盘抽奖安卓应用示例代码四、补充抽奖逻辑实现五、开发传奇开心果轮盘抽奖苹果手机应用编程思路六、开发传奇开心果轮盘抽奖苹果手机应用示例代…

kafka集群和Filebeat+Kafka+ELK

一、Kafka 概述 1.1 为什么需要消息队列&#xff08;MQ&#xff09; 主要原因是由于在高并发环境下&#xff0c;同步请求来不及处理&#xff0c;请求往往会发生阻塞。比如大量的请求并发访问数据库&#xff0c;导致行锁表锁&#xff0c;最后请求线程会堆积过多&#xff0c;从…

专业ScrumMaster(高级)- PSM II 认证班,Scrum.org认证PSM II官方认证班

课程简介 Scrum是目前运用最为广泛的敏捷开发方法&#xff0c;是一个轻量级的项目管理和产品研发管理框架&#xff0c;旨在最短时间内交付最大价值。根据2022年全球敏捷状态报告&#xff0c;Scrum的应用占比已经达到87%。 Scrum.org 由 Scrum 的联合创始人 Ken Schwaber 创立…

[亲测有效]CentOS7下安装mysql5.7

前言 近期项目需要搭配mysql一起存储相关数据&#xff0c;但对mysql的版本有要求&#xff0c;于是在服务器搭建了mysql5.7&#xff0c;顺便记录一下搭建步骤和踩坑解决步骤。 目录 前言 一、清除旧安装包 二、安装YUM 三、使用yum命令即可完成安装 四、重新设置密码 五、…

C#winform上位机开发学习笔记5-串口助手的定时发送功能添加

1.功能描述 选择自动发送功能后&#xff0c;按照设定的发送时间发送发送框中的信息数据&#xff0c;设定时间可以手动输入&#xff0c;当手动输入信息无效&#xff08;非数字&#xff09;时&#xff0c;系统弹出错误提示&#xff0c;并将其设置为默认定时时间。 2.代码部分 步…

【Gene Expression Prediction】Part3 Deep Learning in Gene Expression Analysis

文章目录 6 第二个讲座&#xff1a;Deep Learning in Gene Expression Analysis6.1 Introduction6.2 D-GEX6.2.1 Connectivity map project6.2.2 Predicting gene expression from landmark genes 6.3 Deep generative models for genomics6.3.1 Manifold hypothesis6.3.2 Auto…

【C++】Qt:QCustomPlot图表绘制库配置与示例

&#x1f60f;★,:.☆(&#xffe3;▽&#xffe3;)/$:.★ &#x1f60f; 这篇文章主要介绍QCustomPlot图表绘制库配置与示例。 学其所用&#xff0c;用其所学。——梁启超 欢迎来到我的博客&#xff0c;一起学习&#xff0c;共同进步。 喜欢的朋友可以关注一下&#xff0c;下次…

2024/1/17 DFS BFS + Div 3 a,b

目录 Lake Counting S 求细胞数量 海战 组合的输出 div3 A. Square div3 B. Arranging Cats Lake Counting S P1596 [USACO10OCT] Lake Counting S - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 感谢大佬的指点&#xff01;&#xff01;&#xff01;&#xff01; 思…

k8s使用ingress实现应用的灰度发布升级

v1是1.14.0版本nginx ,实操时候升级到v2是1.20.0版本nginx&#xff0c;来测试灰度发布实现过程 一、方案&#xff1a;使用ingress实现应用的灰度发布 1、服务端&#xff1a;正常版本v1&#xff0c;灰度升级版本v2 2、客户端&#xff1a;带有请求头versionv2标识的请求访问版…

老套的购物车效果

一、项目文件结构 二、各个文件内容 index.html <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta http-equiv"X-UA-Compatible" content"IEedge" /><meta name"viewport…

【C语言进阶】预处理详解

引言 对预处理的相关知识进行详细的介绍 ✨ 猪巴戒&#xff1a;个人主页✨ 所属专栏&#xff1a;《C语言进阶》 &#x1f388;跟着猪巴戒&#xff0c;一起学习C语言&#x1f388; 目录 引言 预定义符号 #define定义常量 #define定义宏 带有副作用的宏参数 宏替换的规则 …

算法基础学习|双指针算法

双指针算法 代码模板 for (int i 0, j 0; i < n; i ){while (j < i && check(i, j)) j ;// 具体问题的逻辑 } 常见问题分类&#xff1a;(1) 对于一个序列&#xff0c;用两个指针维护一段区间(2) 对于两个序列&#xff0c;维护某种次序&#xff0c;比如归并…

echarts绘制饼图,部分数据隐藏指示线和文本,hover时隐藏指示线和文本的类别也不显示tooltip提示

option {tooltip: {trigger: item,formatter: (p) > {if (p.name) {return ${p.name}&#xff1a;${p.value}个;}},backgroundColor: #ffffff,textStyle: { color: #666666 } // 提示标签字体颜色},legend: {top: 5%,left: center},series: [{name: Access From,type: pie,…