【springBoot学习篇】springBoot集成mybatis

目录

第一步:新建spring项目的时候,需要勾选mybatis框架和jdbc连接数据库的包

第二步:在resource目录下面的配置文件当中添加以下的内容:配置数据源

第三步:配置实体类

第四步:添加一个对象的增删改查方法

查询定义:

①查询所有:

 ②条件查询:

新增操作

删除操作

更新操作:

字段不一致的时候映射:

第一步:新建spring项目的时候,需要勾选mybatis框架和jdbc连接数据库的包

然后,检查pom.xml当中是否包含了以下的几个内容:

mybatis的依赖以及mysql连接数据库的依赖;


第二步:在resource目录下面的配置文件当中添加以下的内容:配置数据源

配置数据源:

spring.application.name=demo30
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.password=20021111aA#
spring.datasource.username=root
spring.datasource.url=jdbc:mysql://localhost:3306/my_blog_system?characterEncoding=utf8&useSSL=false

第三步:配置实体类

此处以一个user为例,这边需要配置一个user对象;这个对象在数据库当中对应的也是一个实体;

这里面的属性需要和数据库当中的user一一对应 

package com.example.demo.Entity;import lombok.Data;/*** @author 25043*/
@Data
public class User {private int userId;private String username;private String password;
}

第四步:添加一个对象的增删改查方法

查询定义:

①查询所有:

新建一个mybatis目录,下面定义一个类;在此类当中定义一个查询的方法:

@Mapper注解用于标注持久层的对象;

@Select注解用来编写查询数据库的语句;

queryUserList方法用来返回查询数据库的内容。 

/*** 访问数据库* @author 25043*/
@Mapper
public interface UserInfoMapper {/*** 返回数据列表* 查询列表@return*/@Select("select * from user")List<User> queryUserList();
}

 ②条件查询:

当传入userId的时候,相当于在select语句当中添加了查询userId的操作

    //方法可以传入需要查询的参数@Select("select * from user where userId = #{userId}")User queryUserById(Integer userId);

传入参数重命名:当方法传入的userId和Param里面的id一致的时候,就不需要参数重命名,否则就需要通过@Param注解重命名这个参数;让@Param注解的参数和#后面的一致

    /**方法可以传入需要查询的参数** 用户的uid@param userId* user对象@return*/@Select("select * from user where userId = #{id}")User queryUserById(@Param("id") Integer userId);

新增操作

在下面的步骤当中,insert语句的values当中,username和password都是user的属性。因此直接提取参数即可。这个参数就是方法传入的user的两个属性的值:username,password

    /*** 传入的username和password为对应user的属性* 新增的user都西昂@param user* 插入成功,返回1@return*/@Insert("insert into user(username, password) "+" values(#{username},#{password})")Integer insert(User user);

删除操作

如下面的操作所示,就是删除操作:根据id删除:需要使用到@Delete注解。

   /*** 用户的id@param id* 删除这个user@return*/@Delete("delete from user where userId = #{id}")Integer delete(Integer id);

更新操作:

    /*** 更新* 密码@param password* 用户的id@param id*/@Update("update user set password=#{password} where userId=#{id}")Integer update(String password,Integer id);

字段不一致的时候映射:

首先需要定义一个BaseResult,其中的value为定义的数据库字段的映射;

@Mapper
public interface UserInfoMapper {/**方法可以传入需要查询的参数** 用户的uid@param userId* user对象@return*///第一步:定义一个BaseResult:value的值为@Result注解里面数据库实体之间的映射@Results(id ="BaseResult" ,value = {//column为数据库当中的字段,property为实体的字段名称@Result(column = "password1" ,property = "password")})//第二步:在对应查询的方法上面标注value="BaseResult",那么就可以查询出来对应的user对象了@ResultMap(value = "BaseResult")@Select("select * from user where userId = #{id}")User queryUserById(@Param("id") Integer userId);
}

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

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

相关文章

上位机图像处理和嵌入式模块部署(h750 mcu和图像处理)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 前面我们说过&#xff0c;h750和之前的103、407相比较&#xff0c;本身cpu频率比较高&#xff0c;flash大小一般&#xff0c;但是ram比较大&#x…

群辉其它方案远程访问(ZeroTier篇)

目录 1、注册ZeroTier 2、创建网络 3、下载安装客户端 (1)Windows (2)移动端 i.Android i.iOS (a)注册新ID (b)登陆苹果应用商店 iii.群辉NAS 4、客户端加入网络 (a)Windows (b)Android (c)群辉NAS 5、使用 群辉的远程访问,最标准的做法就是使用…

自动控制原理【期末复习】(二)

无人机上桨之后可以在调试架上先调试&#xff1a; 1.根轨迹的绘制 /// 前面针对的是时域分析&#xff0c;下面针对频域分析&#xff1a; 2.波特图 3.奈维斯特图绘制 1.奈氏稳定判据 2.对数稳定判据 3.相位裕度和幅值裕度

【全篇】Python从零基础到入门

文章目录 第一章 基础语法1.字面量2.注释3.变量4.数据类型5.数据类型转换6.标识符7.运算符8.字符串拓展1.字符串的三种定义方式2.字符串拼接&#xff08;不用&#xff09;3.字符串格式化&#xff08;了解&#xff09;4.格式化的精度控制5.字符串格式化2&#xff08;常用&#x…

跟《经济学人》学英文:2024年6月8日这期:Part 01

本文是对《经济学人》杂志2024.6.8这期的英文学习。 Narendra Modi looks likely to serve a third term as India’s prime minister, after his Bharatiya Janata Party and its allies won a slim majority. The ruling alliance won 293 seats, compared with the opposi…

【代码随想录】【算法训练营】【第36天】[452]用最少数量的箭引爆气球 [435]无重叠区间 [763]划分字母区间

前言 思路及算法思维&#xff0c;指路 代码随想录。 题目来自 LeetCode。 day 36&#xff0c;周三&#xff0c;最难坚持的一天~ 题目详情 [452] 用最少数量的箭引爆气球 题目描述 452 用最少数量的箭引爆气球 解题思路 前提&#xff1a;区间可能重叠 思路&#xff1a;…

YOLO系列理论解读 v1 v2 v3

YOLO系列理论解读 YOLO v1&#xff08;You Only Look Once:Unified, Real-Time Object Detection&#xff09; YOLO v1实现步骤 将一幅图像分成SxS个网格(grid cell)&#xff0c;如果某个object的中心落在这个网格中&#xff0c;则这个网格就负责预测这个object。 通常情况…

服务器无法远程桌面连接,解决服务器进行无法远程桌面连接方法有哪些

当服务器无法建立远程桌面连接时&#xff0c;通常涉及多个层面的排查和修复。下面将详细列举一些专业的解决方法&#xff0c;以应对服务器远程桌面连接问题。 一、基础排查与验证 1. 确认网络连通性&#xff1a; - 使用ping命令检查客户端与服务器之间的网络连通性。 - …

数组(C语言)(详细过程!!!)

目录 数组的概念 一维数组 sizeof计算数组元素个数 二维数组 C99中的变⻓数组 数组的概念 数组是⼀组相同类型元素的集合。 数组分为⼀维数组和多维数组&#xff0c;多维数组⼀般比较多见的是二维数组。 从这个概念中我们就可以发现2个有价值的信息&#xff1a;(1)数…

什么是相对路径?什么是绝对路径?打包时路径怎么搞?

简单点说&#xff1a; 绝对路径&#xff1a;绝对路径是一个完整的路径&#xff0c;从根目录开始一直到目标文件或目录的路径。通常我们直接使用"/ "代表从根目录开始的目录路径。它提供了文件或目录在文件系统中的确切位置&#xff0c;与当前工作目录无关。绝对路径…

AMS深入浅出

目标&#xff1a; 1. 一、AMS启动流程 ActivityManagerService是 安卓10 以后&#xff0c;将AMS拆分出ActivityTaskManagerService。 1.1 启动入口 AMS是由SystemServer进程启动&#xff0c;在启动过程 startBootStripService&#xff0c;会启动AMS和ATMS服务。 SystemSe…

外卖跑腿APP开发指南:探索同城O2O系统源码技术要点

同城O2O系统作为这类服务的技术支撑平台&#xff0c;承载了外卖跑腿APP的开发与运行。本篇文章&#xff0c;小编将深入探讨同城O2O系统源码的技术要点&#xff0c;为外卖跑腿APP的开发提供指导与参考。 一、同城O2O系统概述 同城O2O系统是一种基于地理位置的线上到线下服务平台…

“论多源数据集成及应用”必过范文,突击2024软考高项论文

论文真题 在如今信息爆炸的时代&#xff0c;企业、组织和个人面临着大量的数据。这些数据来自不同的渠道和资源&#xff0c;包括传感器、社交媒体、销售记录等&#xff0c;它们各自具有不同的数据格式、分布和存储方式。因此如何收集、整理和清洗数据&#xff0c;以建立一个一…

阅读源码解析dynamic-datasource-spring-boot-starter中是如何动态切换数据源的

dynamic-datasource-spring-boot-starter是苞米豆提供的一个动态切换数据源的工具&#xff0c;可以帮助企业或者个人实现多数据源的切换&#xff0c;这里通过阅读源码的方式解析是如何动态的切换数据源的&#xff0c;采用的版本是3.5.1 源码解析 通过官方文档可以看到&#x…

vue 和 js写屏幕自适应

实现屏幕自适应的方式有很多种&#xff0c;可以通过插件本身提供的方法&#xff0c;可以通过flex布局等&#xff0c;今天我们来写写通过js实现屏幕自适应。 以下是在vue中实现的屏幕自适应 首先在data中定义一下屏幕的默认大小和缩放比例 然后在mounted中获取窗口的内置宽高&a…

揭秘软件测试秘籍:测试用例设计方法大揭秘

文章目录 引言一、等价类划分1.1 定义1.2 步骤1.3 等价类划分优点和缺点 二、边界值分析法2.1 定义2.2 步骤2.3 边界值分析法的优点和缺点 三、判定表法3.1 定义3.2 步骤3.3 判定表组成不分3.4 判定表的优点和缺点 四、正交实验法4.1 定义4.2 步骤4.3 正交实验法的优点和缺点 五…

基于Verilog表达的FSM状态机

基于Verilog表达的FSM状态机 1 FSM1.1 Intro1.2 Why FSM?1.3 How to do 在这里聚焦基于Verilog的三段式状态机编程&#xff1b; 1 FSM 1.1 Intro 状态机是一种代码实现功能的范式&#xff1b;一切皆可状态机&#xff1b; 状态机编程四要素&#xff1a;– 1.状态State&#…

基于51单片机的简易温控水杯恒温杯仿真设计( proteus仿真+程序+设计报告+讲解视频)

基于51单片机的简易温控水杯恒温杯仿真设计( proteus仿真程序设计报告讲解视频&#xff09; 仿真图proteus7.8及以上 程序编译器&#xff1a;keil 4/keil 5 编程语言&#xff1a;C语言 设计编号&#xff1a;S0099 1. 主要功能&#xff1a; 基于51单片机的简易温控水杯恒温…

【课程总结】Day8(上):深度学习基本流程

前言 在上一篇课程《【课程总结】Day7&#xff1a;深度学习概述》中&#xff0c;我们了解到&#xff1a; 模型训练过程→本质上是固定w和b参数的过程&#xff1b;让模型更好→本质上就是让模型的损失值loss变小&#xff1b;让loss变小→本质上就是求loss函数的最小值&#xf…

史上最全盘点:一文告诉你什么是erp?erp系统厂商分别有哪些?

✅ 什么是ERP&#xff1f; ERP是Enterprise Resource Planning&#xff08;企业资源计划&#xff09;的简称&#xff0c;ERP是针对物资资源管理&#xff08;物流&#xff09;、人力资源管理&#xff08;人流&#xff09;、财务资源管理&#xff08;资金流&#xff09;、信息资…