【JavaEE】Mybatis基础使用注解 增删改查操作

目录

  • 一、配置日志
  • 二、传递参数 #{}
  • 三、增(@Insert)
  • 四、返回主键@Options
  • 五、删(@Delete)
  • 六、改(@Update)
  • 七、查(@Select)

一、配置日志

我们加上下面的代码在配置文件中,那么我们在日志中就可以看到我们执行的操作,和数据库返回的数据。

# 配置打印 MyBatis⽇志 
mybatis:configuration: log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

二、传递参数 #{}

当我们的SQL语句中,要根据参数来操作时,我们通过 注解传参的时候可以使用#{参数名}来将后端的参数传给数据库。

@Select("select * from user_info where id = #{id}")UserInfo selectOne(Integer id) ;

查询结果:

注意事项:

  • 当我们数据库返回的只有1行或者0行数据的时候,我们使用对象接收不会报错。
  • 当有多条数据返回时,适用对象接收就会报错,应该使用集合。
  • 后端的参数名强烈建议在注解#{}中的参数名要相同。
  • 当后端只有一个参数的时候,#{}中的参数无论怎么写都可以正确传参。
  • 当后端有多个参数的时候,Mybatis会将参数根据顺序转换为param1,param2,也可以根据这个来传参。
  • 也可以通过 @Param , 设置参数的别名, 如果使⽤ @Param 设置别名, #{…}⾥⾯的属性名必须和@Param 设置的⼀样.

三、增(@Insert)

使用注解@Insert来写入数据,直接使⽤UserInfo对象的属性名来获取参数。

@Insert("insert into user_info (username, password, age) values (#{username},#{password},#{age})")Integer insertOne(UserInfo userInfo);

测试函数:

    @Testvoid insertOne() {UserInfo userInfo = new UserInfo();userInfo.setAge(6);userInfo.setPassword("666");userInfo.setUsername("666");Integer result = userMapper.insertOne(userInfo);System.out.println("增加行数:"+ result);}

结果:

四、返回主键@Options

insert 语句默认返回的是 受影响的⾏数, 但有些情况下, 数据插⼊之后, 还需要有后续的关联操作, 需要获取到新插⼊数据的主键,这时就需要使用注解@Options。

	@Insert("insert into user_info (username, password, age) values (#{username},#{password},#{age})")@Options(useGeneratedKeys = true, keyProperty = "id")Integer insertOne(UserInfo userInfo);
  • useGeneratedKeys:这会令 MyBatis 使⽤ JDBC 的 getGeneratedKeys ⽅法来取出由数据库内部⽣成的主键(⽐如:像 MySQL 和 SQL Server 这样的关系型数据库管理系统的⾃动递增字段),默认值:false.
  • keyProperty:指定能够唯⼀识别对象的属性,MyBatis 会使⽤ getGeneratedKeys 的返回值或 insert 语句的 selectKey ⼦元素设置它的值,默认值:未设置(unset)

测试方法:

@Testvoid insertOne() {UserInfo userInfo = new UserInfo();userInfo.setAge(7);userInfo.setPassword("777");userInfo.setUsername("777");Integer result = userMapper.insertOne(userInfo);System.out.println("增加函数:"+ result+", 增加数据的id:"+userInfo.getId());}

结果:
、

五、删(@Delete)

使用@Delete注解,加上删除的SQL语句即可。

	@Delete("delete from user_info where id = #{id}")Integer deleteUser(Integer id);

测试方法:

    @Testvoid deleteUser() {userMapper.deleteUser(7);}

结果:

六、改(@Update)

修改数据直接使用@Update注解,加上修改SQL语句即可。

	@Update("update user_info set delete_flag = #{deleteFlag} where id = #{id};")Integer updateUser(UserInfo userInfo);

测试方法:

    @Testvoid updateUser() {UserInfo userInfo = new UserInfo();userInfo.setId(6);userInfo.setDeleteFlag(1);userMapper.updateUser(userInfo);}

结果:

七、查(@Select)

当我们要查询数据的时候直接使用@Select注解加上查询语句即可。

 @Select("select * from user_info")List<UserInfo> selectAll() ;

但是由于我们的类的属性名与数据库的字段名不一致时,会出现数据库该字段有返回值,但是不能复制给类中的对应属性。

我们有以下三种方式解决:

  1. 使用查询语句时将数据库不同字段名取别名为属性名。
@Select("select username , password, age, gender, phone, " +"delete_flag as deleteFlag , create_time as createTime, update_time as updateTime " +"from user_info")List<UserInfo> selectAll() ;
  1. 使用注解@Result和@Results。在@Results注解中放入@Result注解数组,@Result注解的column属性对应数据库字段,property属性对应类属性名。
@Results(value = {@Result(column = "delete_flag", property = "deleteFlag"),@Result(column = "create_time", property = "createTime"),@Result(column = "update_time", property = "updateTime"),})@Select("select * from user_info ")List<UserInfo> selectAll() ;
  1. 当我们想要将上面的@Results这一大段迁移使用@ResultMap注解,在@Results注解的id属性中写上名字即可。只能引用同一个类中的@Results注解。
 @Results(id = "userInfoMap",value = {@Result(column = "delete_flag", property = "deleteFlag"),@Result(column = "create_time", property = "createTime"),@Result(column = "update_time", property = "updateTime"),})@Select("select * from user_info ")List<UserInfo> selectAll() ;@ResultMap("userInfoMap")@Select("select * from user_info where id = #{id}")UserInfo selectId(Integer id) ;
  1. 使用配置文件将数据库字段中使用下划线的蛇形命名转换为小驼峰命名。mybatis.configuration.map-underscore-to-camel-case: true
mybatis:configuration:map-underscore-to-camel-case: true #配置驼峰⾃动转换

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

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

相关文章

4.2、网络安全体系与建设内容

目录 网络安全体系架构网络安全组织安全管理网络安全等级保护2.0等保项目流程等保标准变化等保2.0新增内容等保2.0变化智慧城市安全体系应用参考智能交通网络安全体系应用参考 网络安全体系架构 建设网络安全&#xff0c;要体系化&#xff0c;要从一个整体去做考虑&#xff0c…

TCP协议原理

TCP协议原理 本篇介绍 前面已经基本介绍了TCP编程的接口以及基本的步骤&#xff0c;但是并没有其中的原理进行解释。本篇主要聚焦于TCP原理部分&#xff0c;对TCP中重要的内容进行解释 TCP协议报格式 基本示意图如下&#xff1a; 下面针对每一个字段的作用进行简要的概括&a…

go中的文件、目录的操作

1.文件的概念 文件是数据源(保存数据的地方)的一种,比如大家经常使用的word文档,txt文件,excel文件等。文件最主要的作用就是保存数据,它既可以保存一张图片,也可以保存视频,声音等。 文件在程序中以流的形式来操作的。 流:数据在数据源(文件)和程序(内存)之间…

electron js node vscode 调试electron

用npm会下到home里面不知道为什么可能是淘宝源的问题 --------------------------------- 安装cnpm&#xff08;可选&#xff09; sudo npm install -g cnpm --registryhttps://registry.npmmirror.com下下来还没办法直接用 sudo find / -name "cnpm"nano ~/.bashr…

深度解析 BPaaS:架构、原则与研发模式探索

在当今复杂多变的业务环境下&#xff0c;软件开发面临着诸多挑战&#xff0c;如何有效地管理业务复杂性并实现系统的可扩展性成为关键。BPaaS应运而生&#xff0c;它作为一种创新的理念和架构模式&#xff0c;改变着企业研发的方式。本文将深入探讨 BPaaS 是什么&#xff0c;以…

大模型架构记录2 【综述-相关代码】

一 简单聊天机器人搭建 1.1 openai调用 import os from openai import OpenAI from dotenv import load_dotenv, find_dotenvload_dotenv() client OpenAI()# 打印所支持的模型 model_lst client.models.list()for model in model_lst:print (model.id)# 调用API接口 comp…

三个print优雅打印datetime模块的“时间密码”

三个模块&三条print()&#xff0c;玩转python时间的上上下下&#xff0c;优雅打印“时间密码”。 笔记模板由python脚本于2025-03-23 22:50:43创建&#xff0c;本篇笔记适合正确研究时间/日期的coder翻阅。 【学习的细节是欢悦的历程】 博客的核心价值&#xff1a;在于输出…

【Android】VehiclePropertyAccess引起CarService崩溃

VehiclePropertyAccess引起CarService崩溃 VehiclePropertyAccess VehiclePropertyAccess属性&#xff0c;用于定义车辆属性的访问权限。权限包括 读&#xff1a;READ&#xff0c;只可以读取&#xff0c;不能写入。 VehiclePropertyAccess:READ写&#xff1a;WRITE&#xf…

深入理解traceroute命令及其原理

traceroute 是一个网络诊断工具&#xff08;Windows上叫tracert&#xff09;&#xff0c;用于显示数据包从本地主机到远程主机经过的路由&#xff08;跳数&#xff09;。它可以帮助您了解数据包在网络中的传输路径&#xff0c;以及每跳的延迟情况。这对于网络故障排除、分析网络…

Playwright + MCP:用AI对话重新定义浏览器自动化,效率提升300%!

一、引言&#xff1a;自动化测试的“瓶颈”与MCP的革新 传统自动化测试依赖开发者手动编写脚本&#xff0c;不仅耗时且容易因页面动态变化失效。例如&#xff0c;一个简单的登录流程可能需要开发者手动定位元素、处理等待逻辑&#xff0c;甚至反复调试超时问题。而MCP&#xf…

JVM 学习前置知识

JVM 学习前置知识 Java 开发环境层次结构解析 下图展示了 Java 开发环境的层级关系及其核心组件&#xff0c;从底层操作系统到上层开发工具&#xff0c;逐步构建完整的开发与运行环境&#xff1a; 1. 操作系统&#xff08;Windows, MacOS, Linux, Solaris&#xff09; 作用&…

【Java/数据结构】队列(Quque)

本博客将介绍队列的相关知识&#xff0c;包括基于数组的普通队列&#xff0c;基于链表的普通队列&#xff0c;基于数组的双端队列&#xff0c;基于链表的双端队列&#xff0c;但不包括优先级队列&#xff08;PriorityQueue&#xff09;&#xff0c;此数据结构将单独发一篇博客&…

深度学习Python编程:从入门到工程实践

第一章 Python语言概述与生态体系 1.3 Python在工业界的应用场景 # 示例:使用FastAPI构建RESTful接口 from fastapi import FastAPI from pydantic import BaseModelapp = FastAPI()class Item(BaseModel):name: strprice: float@app.post("/items/") async def cr…

Flutter 学习之旅 之 flutter 使用 connectivity_plus 进行网路状态监听(断网/网络恢复事件监听)

Flutter 学习之旅 之 flutter 使用 connectivity_plus 进行网路状态监听&#xff08;断网/网络恢复事件监听&#xff09; 目录 Flutter 学习之旅 之 flutter 使用 connectivity_plus 进行网路状态监听&#xff08;断网/网络恢复事件监听&#xff09; 一、简单介绍 二、conne…

matlab的meshgrid

文章目录 一、什么是 meshgrid&#xff1f;二、基本语法三、为什么需要 meshgrid&#xff1f;四、meshgrid 与 ndgrid 的区别 一、什么是 meshgrid&#xff1f; meshgrid 是 MATLAB 中用于生成网格点坐标矩阵的函数&#xff0c;常用于三维绘图&#xff08;如 surf, mesh, cont…

word插入Mathtype公式居中和自动更新

word插入公式自动更新 前提&#xff1a;安装Mathtype 1.word中查看页的宽度 出现如下 2.设置样式 出现这个窗口 给样式随便起个名字 3.修改样式 3.1 设置两个制表位 第二个 3.2 修改公式字体 如下所示 4. 修改公式格式 4.1在word中打开 Mathtype 4.2 修改公式的格式 变成…

用 pytorch 从零开始创建大语言模型(六):对分类进行微调

用 pytorch 从零开始创建大语言模型&#xff08;六&#xff09;&#xff1a;对分类进行微调 6 微调用于分类6.1 微调的不同类别6.2 准备数据集6.3 创建数据加载器6.4 使用预训练权重初始化模型6.5 添加分类头部6.6 计算分类损失和准确率6.7 在监督数据上微调模型6.8 使用LLM进…

阿里云对象存储教程

搜“对象存储->免费试用” 选择你的心仪产品&#xff0c;我使用的是第一个 创建后获得三个实例&#xff1a; 点击右上角自己的账号可以进入到AccessKey管理界面 回到对象存储控制台创建Bucket实例 在以下文件中替换自己Bucket的信息即可美美使用~ package com.kitty.blog…

基于Python的智慧金融风控系统的设计与实现

指导途径&#xff08;&#x1f6f0;&#xff09;&#xff1a;NzqDssm16 1立题依据 1.1毕业论文&#xff08;设计&#xff09;的研究背景 随着金融行业数字化转型加速&#xff0c;智能风控系统成为防范金融风险的核心支撑。传统风控手段存在数据处理效率低下、模型更新滞后、人…

分布式算法:Paxos Raft 两种共识算法

1. Paxos算法 Paxos算法是 Leslie Lamport&#xff08;莱斯利兰伯特&#xff09;在 1990 年提出的一种分布式系统共识算法。也是第一个被证明完备的共识算法&#xff08;前提是不存在恶意节点&#xff09;。 1.1 简介 Paxos算法是第一个被证明完备的分布式系统共识算法。共识…