Mybatis的<insert>,<update>,<delete>标签用法

简介: 这篇文章详细讲解了Mybatis中<insert>, <update>, <delete>标签的使用方法,并提供了示例代码来展示如何执行数据库的增删改操作。

之前对mybatis的<select>标签以及其他相关标签做了讲解,很多标签也是可以拿到增删改的标签中来用的,下面先说下<insert>标签的用法:

<insert>标签顾名思义就是插入语句,用于将数据插入到数据库中,一般插入标签没有返回值,传入一个实体对象的数据,一般不对插入的数据做判断,因为是新的一笔数据,即使是null值也可以插入,一些业务逻辑的判断应该放在前端实现。下面写一个例子:

<insert id="insertUser" parameterType="User">
  INSERT INTO sys_user (name, age, email)
  VALUES (#{name}, #{age}, #{email})
</insert>

但是有时候存在子表数据一起插入的情况,而此时数据库的id又是自增长,那么就需要返回插入数据的id,用来作为从表的外键插入到数据库,需要引入一个新的标签<selectKey>专门用来查询插入后返回的id。那么插入语句就可以改成这个样子:

<insert id="insertUser" parameterType="User">
  <selectKey keyProperty="id" resultType="int" order="AFTER">
    SELECT LAST_INSERT_ID()
  </selectKey>
  INSERT INTO sys_user (name, age, email)
  VALUES (#{name}, #{age}, #{email})
</insert>

还有一种实现方式是通过给insert标签添加属性来实现:

<insert id="insertUser" usegeneratedKeys="true" keyProperty="id" parameterType="User">
  INSERT INTO sys_user (name, age, email)
  VALUES (#{name}, #{age}, #{email})
</insert>

<update>的实现方式也是如此,只不过update正常都是通过id修改,不会需要返回id,不过<update>标签需要注意的是有时候会希望返回影响的行数,那么同样可以用<selectKey>标签,具体代码如下:

<update id="updateUser" parameterType="User" statementType="PREPARED">
  <selectKey keyProperty="rowCount" resultType="int" order="AFTER">
    SELECT ROW_COUNT()
  </selectKey>
  UPDATE sys_user
  SET name = #{name}, age = #{age}, email = #{email}
  WHERE id = #{id}
</update>

同时,<update>还经常存在一种需求是如果传入的值为null则不修改数据库原有的值,如果传入的数据是有效值,则修改原有的值,那么这里就要结<if>标签做一些判断了。这里要引入一个标签<set>,例子如下:

<update id="updateUser" parameterType="User">
  UPDATE sys_user
  <set>
    <if test="name != null">
      name = #{name},
    </if>
    <if test="age != null">
      age = #{age},
    </if>
    <if test="email != null">
      email = #{email},
    </if>
  </set>
  WHERE id = #{id}
</update>

不希望更新传入数据为null的值,也就是传入的字段有值则修改,如果没有值则不修改,不过要注意的是起码要保证有一个条件是存在的,否则sql会成为以下这样:update sys_user where id = #{id},这样sql是报错的。

<delete> 最后再说下标签,这个标签也是最简单的,只需要判断条件是否满足然后删除掉对应的数据就好了,例子:

<delete id="deleteUser" parameterType="int">
  DELETE FROM 
  WHERE id = #{userId}
</delete>

也可以判断条件的是否存在,但是一般删除操作比较谨慎,不会多条件筛选删除。否则会出现误删的清理,判断条件的方式与查询里的方式一致,可以参考查询里的实现方式。

好了,已上如有问题可以在评论区给我留言

相关文章
|
3月前
|
SQL XML Java
mybatis复习04高级查询 一对多,多对一的映射处理,collection和association标签的使用
文章介绍了MyBatis中高级查询的一对多和多对一映射处理,包括创建数据库表、抽象对应的实体类、使用resultMap中的association和collection标签进行映射处理,以及如何实现级联查询和分步查询。此外,还补充了延迟加载的设置和用法。
mybatis复习04高级查询 一对多,多对一的映射处理,collection和association标签的使用
|
2月前
|
SQL XML Java
Mybatis的<where>,<if>等标签用法
这篇文章详细解释了Mybatis中<where>和<if>等标签的用法,展示了如何在SQL动态构建中有效地过滤条件和处理逻辑分支。
254 1
|
2月前
|
SQL Java 数据库连接
Mybatis入门(select标签)
这篇文章介绍了Mybatis中`select`标签的基本用法及其相关属性,并通过示例展示了如何配置和执行SQL查询语句。
52 0
Mybatis入门(select标签)
|
2月前
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
145 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
|
2月前
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
73 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
|
2月前
|
前端开发 Java Apache
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
本文详细讲解了如何整合Apache Shiro与Spring Boot项目,包括数据库准备、项目配置、实体类、Mapper、Service、Controller的创建和配置,以及Shiro的配置和使用。
501 1
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
|
2月前
|
SQL Java 数据库连接
mybatis使用二:springboot 整合 mybatis,创建开发环境
这篇文章介绍了如何在SpringBoot项目中整合Mybatis和MybatisGenerator,包括添加依赖、配置数据源、修改启动主类、编写Java代码,以及使用Postman进行接口测试。
26 0
mybatis使用二:springboot 整合 mybatis,创建开发环境
|
2月前
|
Java 数据库连接 API
springBoot:后端解决跨域&Mybatis-Plus&SwaggerUI&代码生成器 (四)
本文介绍了后端解决跨域问题的方法及Mybatis-Plus的配置与使用。首先通过创建`CorsConfig`类并设置相关参数来实现跨域请求处理。接着,详细描述了如何引入Mybatis-Plus插件,包括配置`MybatisPlusConfig`类、定义Mapper接口以及Service层。此外,还展示了如何配置分页查询功能,并引入SwaggerUI进行API文档生成。最后,提供了代码生成器的配置示例,帮助快速生成项目所需的基础代码。
151 1
|
3月前
|
缓存 前端开发 Java
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
Soring Boot的起步依赖、启动流程、自动装配、常用的注解、Spring MVC的执行流程、对MVC的理解、RestFull风格、为什么service层要写接口、MyBatis的缓存机制、$和#有什么区别、resultType和resultMap区别、cookie和session的区别是什么?session的工作原理
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
|
2月前
|
前端开发 Java 数据库连接
表白墙/留言墙 —— 中级SpringBoot项目,MyBatis技术栈MySQL数据库开发,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
本文是一份全面的表白墙/留言墙项目教程,使用SpringBoot + MyBatis技术栈和MySQL数据库开发,涵盖了项目前后端开发、数据库配置、代码实现和运行的详细步骤。
73 0
表白墙/留言墙 —— 中级SpringBoot项目,MyBatis技术栈MySQL数据库开发,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学