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>

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

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

相关文章
|
SQL Java 数据库连接
MyBatis-Plus的几种常见用法
MyBatis-Plus 为 MyBatis 提供了许多增强功能,使得开发更加便捷高效。通过基础的 CRUD 操作、条件构造器、分页插件和自动填充等功能,开发者可以显著减少代码量,提高开发效率。在实际应用中,根据具体需求选择合适的功能模块,能够更好地利用 MyBatis-Plus 提升项目开发效率。
418 22
|
SQL Java 数据库连接
MyBatis-Plus高级用法:最优化持久层开发
MyBatis-Plus 通过简化常见的持久层开发任务,提高了开发效率和代码的可维护性。通过合理使用条件构造器、分页插件、逻辑删除和代码生成器等高级功能,可以进一步优化持久层开发,提升系统性能和稳定性。掌握这些高级用法和最佳实践,有助于开发者构建高效、稳定和可扩展的企业级应用。
805 13
mybatis复习04高级查询 一对多,多对一的映射处理,collection和association标签的使用
文章介绍了MyBatis中高级查询的一对多和多对一映射处理,包括创建数据库表、抽象对应的实体类、使用resultMap中的association和collection标签进行映射处理,以及如何实现级联查询和分步查询。此外,还补充了延迟加载的设置和用法。
mybatis复习04高级查询 一对多,多对一的映射处理,collection和association标签的使用
|
SQL XML Java
Mybatis的<where>,<if>等标签用法
这篇文章详细解释了Mybatis中<where>和<if>等标签的用法,展示了如何在SQL动态构建中有效地过滤条件和处理逻辑分支。
960 1
|
SQL Java 数据库连接
Mybatis入门(select标签)
这篇文章介绍了Mybatis中`select`标签的基本用法及其相关属性,并通过示例展示了如何配置和执行SQL查询语句。
336 0
Mybatis入门(select标签)
|
8月前
|
Java 数据库连接 数据库
Spring boot 使用mybatis generator 自动生成代码插件
本文介绍了在Spring Boot项目中使用MyBatis Generator插件自动生成代码的详细步骤。首先创建一个新的Spring Boot项目,接着引入MyBatis Generator插件并配置`pom.xml`文件。然后删除默认的`application.properties`文件,创建`application.yml`进行相关配置,如设置Mapper路径和实体类包名。重点在于配置`generatorConfig.xml`文件,包括数据库驱动、连接信息、生成模型、映射文件及DAO的包名和位置。最后通过IDE配置运行插件生成代码,并在主类添加`@MapperScan`注解完成整合
1361 1
Spring boot 使用mybatis generator 自动生成代码插件
|
11月前
|
XML Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——基于注解的整合
本文介绍了Spring Boot集成MyBatis的两种方式:基于XML和注解的形式。重点讲解了注解方式,包括@Select、@Insert、@Update、@Delete等常用注解的使用方法,以及多参数时@Param注解的应用。同时,针对字段映射不一致的问题,提供了@Results和@ResultMap的解决方案。文章还提到实际项目中常结合XML与注解的优点,灵活使用两者以提高开发效率,并附带课程源码供下载学习。
843 0
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
630 2
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
688 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
670 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块