update语句的返回值是什么

本文围绕MyBatis中update语句的返回值展开。通常认为返回值是受影响的行数,但实际测试发现再次执行相同语句时返回值仍为1。经分析,默认返回值是matched记录数。若想返回受影响的行数,可修改数据库链接配置,增加useAffectedRows=true。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

update语句的返回值是什么
执行一条update语句,执行成功后返回值是 1 ,所以就理所当然的认为返回的是受影响的行数,
但是当你再次执行这条update语句时,按正常的逻辑,数据已存在,更新不会成功,应当返回 0,但是返回值依旧
是 1 (已测试过),所以返回值并不是受影响的行数,查看别人的文章,得知返回值是matched记录数(匹配到的行数)
如果想设置返回值是受影响的行数,修改数据库链接配置:增加 useAffectedRows=true  即可
 

 

 

mybatis 中的 update 返回值你真的明白吗

96豆豆先生的小屋 关注

1.1 2018.03.10 22:35* 字数 544 阅读 10893评论 0喜欢 5

如果定义一个如下的update函数,那么这个函数的返回值到底是啥意思呢?是受影响的行数吗?

函数定义

验证之前我们先看看数据库中的数据记录。总共两条数据记录!

数据记录

数据库链接配置为:

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/ssm
jdbc.username=root
jdbc.password=123456

下面看看我们的单元测试类。

 

单元测试类

我们根据 ID 获取记录,然把用户名由 root 改为 root001。如果说返回值是影响的行数的话,那么应该返回 1.跟我们的预期结果 1 是相符的。单元测试会通过。

单元测试通过

单元测试通过,我们看看数据库中的记录有没有变化。

数据库记录

看起来貌似没有任何问题。单元测试通过,数据库的确是只有一条记录更改了。这说明 mybatis 的 update 操作返回值的确是受影响的行数。

真的是这样吗

我们知道当数据库中的记录被修改之后,我们在次执行相同的 update 语句将不会影响到数据记录行数。

按照这个逻辑来讲的话,在此执行此单元测试,返回值应该为 0,跟我们的预期值 1 不同,单元测试应该不通过。再次运行单元测试:

单元测试通过

我去,单元测试居然神奇般的通过了。。。请注意看,我们在命令行执行 update 语句那张图,返回的 matched 数量为 1。所以默认情况下,mybatis 的 update 操作的返回值是 matched 的记录数,并不是受影响的记录数。

那么有没有办法让 mybatis 的 update 操作的返回值是受影响的行数呢。因为我们业务逻辑中有时会根据这个返回值做业务判断。答案当然是有的。
修改数据库链接配置为:增加了 useAffectedRows 字段信息。

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/ssm?useAffectedRows=true
jdbc.username=root
jdbc.password=123456

再次运行单元测试:

单元测试失败

从报错信息可以清晰的看出,返回值是 0,跟我们的预期值 1 不同。

### SQL 中 UPDATE 语句返回值含义及使用方法 在关系型数据库中,`UPDATE` 语句用于修改表中的现有记录。执行 `UPDATE` 语句后,通常会有一个返回值表示操作的结果。以下是关于 `UPDATE` 返回值的具体含义及其用法。 #### 1. **返回值的常见解释** - 在大多数情况下,`UPDATE` 的返回值代表受该语句影响的行数(即实际发生更改的行数)。如果某些行虽然符合条件但并未发生变化,则这些行不会计入受影响行数[^2]。 - 如果未找到任何符合条件的行,返回值将是 `0`,表明没有任何行受到影响。 #### 2. **MyBatis 和 JDBC 对返回值的支持** - MyBatis 的 `<update>` 标签默认返回一个整数值 (`int`),这个值通常是受影响的行数。然而,默认行为可能因配置而异。例如,在 MySQL 数据库中,可以通过设置连接 URL 参数 `useAffectedRows=true` 来确保返回的是真正受影响的行数而非匹配行数[^1]。 ```java // 配置示例 spring.datasource.url=jdbc:mysql://localhost:3306/db_book?useUnicode=true&characterEncoding=utf8&useSSL=false&useAffectedRows=true ``` - 在 Java 的 JDBC API 中,调用 `Statement.executeUpdate()` 或 `PreparedStatement.executeUpdate()` 执行 `UPDATE` 操作时,也会返回受影响的行数作为结果[^3]。 #### 3. **Python 中的实现方式** - Python 使用 `MySQLdb` 或其他类似的库时,可通过 `cursor.execute(query, args)` 方法执行 `UPDATE` 语句,并获取受影响的行数作为返回值。 ```python import mysql.connector connection = mysql.connector.connect( host="localhost", user="root", password="password", database="test_db" ) cursor = connection.cursor() query = "UPDATE users SET age = %s WHERE id = %s" args = (25, 1) affected_rows = cursor.execute(query, args) connection.commit() print(f"受影响的行数: {cursor.rowcount}") ``` 在此代码片段中,`cursor.rowcount` 提供了受影响的行数。 #### 4. **特殊情况下的返回值** - 当使用某些特定模式(如 Flink 的 `emitUpdateWithRetract()`),可能会涉及更复杂的逻辑处理更新事件[^4]。这种场景下,返回值的意义取决于具体框架的设计。 - 若尝试通过 `SELECT * FROM table_name` 并结合 `ExecuteNonQuery()` 判断是否存在数据,需要注意其返回值可能是 `-1` 而非预期的受影响行数。 #### 5. **自定义函数中的应用** - 在 MySQL 自定义函数中,也可以嵌套 `UPDATE` 语句并利用其返回值完成进一步的操作。例如: ```sql DELIMITER $$ CREATE FUNCTION update_user_age(user_id INT, new_age INT) RETURNS INT DETERMINISTIC BEGIN DECLARE affected_rows INT; UPDATE users SET age = new_age WHERE id = user_id; SELECT ROW_COUNT() INTO affected_rows; -- 获取受影响行数 RETURN affected_rows; END$$ DELIMITER ; ``` 上述例子展示了如何在一个存储过程中捕获 `ROW_COUNT()` 函数的值以反映最近一次 `UPDATE` 操作的影响范围[^5]。 --- ### 示例总结 综上所述,`UPDATE` 语句的主要返回值是受影响的行数,它能够帮助开发者确认哪些记录已被成功修改以及有多少记录发生了变化。不同编程环境和技术栈提供了多种途径来访问这一重要指标。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值