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

embedded/2025/3/29 11:56:16/

目录

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

一、配置日志

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

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

二、传递参数 #{}

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

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

查询结果:

注意事项:

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

三、增(@Insert)

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

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

测试函数:

java">    @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。

java">	@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)

测试方法:

java">@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语句即可。

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

测试方法:

java">    @Testvoid deleteUser() {userMapper.deleteUser(7);}

结果:

六、改(@Update)

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

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

测试方法:

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

结果:

七、查(@Select)

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

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

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

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

  1. 使用查询语句时将数据库不同字段名取别名为属性名。
java">@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属性对应类属性名。
java">@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注解。
java"> @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.ppmy.cn/embedded/176399.html

相关文章

第五: redis 安装 / find 查找目录

redis 安装的 两种方式&#xff1a; mac上安装redis的两种方法_如何在mac上安装redis-CSDN博客 首先可以先看一下brew的常用命令如下&#xff1a; brew search ** //查找某个软件包 brew list //列出已经安装的软件的包 brew install ** //安装某个软件包,默认安装的是…

anythingLLM结合searXNG实现联网搜索

1、docker-compose 部署searXNG GitHub - searxng/searxng-docker: The docker-compose files for setting up a SearXNG instance with docker. cd /usr/local git clone https://github.com/searxng/searxng-docker.git cd searxng-docker 2、修改 .env文件 # By default…

如何设计一个 RPC 框架?需要考虑哪些点?

设计一个完整的 RPC 框架需要覆盖以下核心模块及关键技术点&#xff1a; 一、核心架构模块 模块功能与实现要点服务注册与发现使用 Zookeeper/Nacos 等实现服务地址动态注册与订阅&#xff0c;支持心跳检测和节点变更通知网络通信层基于 Netty 或 gRPC 的 HTTP/2 实现异步非阻…

深度学习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…

HarmonyOS NEXT 组件状态管理的对比

在HarmonyOS NEXT开发中&#xff0c;组件状态管理是构建动态用户界面的核心。本文将深入探讨State、Prop、Link和ObjectLink这四种常见的状态管理装饰器&#xff0c;并通过示例代码进行对比分析&#xff0c;以帮助同学们更好地理解和选择合适的状态管理方式。 一、装饰器概述 …

算法刷题记录——LeetCode篇(2) [第101~200题](持续更新)

更新时间&#xff1a;2025-03-20 LeetCode刷题目录&#xff1a;算法刷题记录——专题目录汇总技术博客总目录&#xff1a;计算机技术系列博客——目录页 优先整理热门100及面试150&#xff0c;不定期持续更新&#xff0c;欢迎关注&#xff01; 101. 对称二叉树 给你一个二叉…

k8s服务中userspace,iptables,和ipvs的比较

在 Kubernetes 中&#xff0c;kube-proxy 是负责实现服务负载均衡的组件。它支持三种代理模式&#xff1a;userspace、iptables 和 ipvs。这三种模式在性能、功能和复杂性上有所不同。以下是它们的详细比较&#xff1a; 1. Userspace 模式 Userspace 是 Kubernetes 最早支持的…

Redis + 布隆过滤器解决缓存穿透问题

Redis 布隆过滤器解决缓存穿透问题 1. Redis 布隆过滤器解决缓存穿透问题 &#x1f4cc; 什么是缓存穿透&#xff1f; 缓存穿透指的是查询的数据既不在缓存&#xff0c;也不在数据库&#xff0c;导致每次查询都直接访问数据库&#xff0c;增加数据库压力。 例如&#xff1…