MySQL - 使用 SET 语句更新查询取决于前一个 SET 语句的结果

标签 mysql sql sql-update

这是我希望通过 UPDATE 语句实现的目标的表格表示。

+----+----+---+---+----+----------+---------------+---------------+
| ID | A  | B | C | D  |  Calc A  |    Calc B     |    Calc C     |
+----+----+---+---+----+----------+---------------+---------------+
|  1 |  6 | 5 | 2 | 10 | =[A]-[B] | =[Calc A]/[D] | =[B]/[Calc B] |
|  2 |  8 | 5 | 2 | 10 | =[A]-[B] | =[Calc A]/[D] | =[B]/[Calc B] |
|  3 | 10 | 5 | 2 | 10 | =[A]-[B] | =[Calc A]/[D] | =[B]/[Calc B] |
+----+----+---+---+----+----------+---------------+---------------+

实现此目的的当前 UPDATE 语句如下...

UPDATE [EXAMPLE]
SET [Calc A]    = A - B
    , [Calc B]  = [Calc A] / D
    , [Calc C]  = B / [Calc B] 

但是它没有按预期工作。 [Calc A] 将在第一次更新时正确计算。但是 [Calc B] 将使用 [Calc A] 中的旧值进行计算,而不是我刚刚写入数据库的新更新值。这适用于 [Calc C],它再次引用 [Calc B] 的旧值。

如果您执行 UPDATE 语句 3 次,数据将正确计算出来。 [Calc A] 在第一次计算中设置正确,然后 [Calc B] 将在第二次 UPDATE 中引用 [Calc A] 的正确更新值,然后 [Calc C] 将在 [Calc B] 中引用正确的更新值第三次更新。

所以我的问题是如何在一个更新语句中将所有列设置为正确的值?

最佳答案

独立计算即可:

update [EXAMPLE]
set [Calc A] = A - B,
    [Calc B] = (A - B) / D,
    [Calc C] = B / ((A - B) / D)

关于MySQL - 使用 SET 语句更新查询取决于前一个 SET 语句的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41906511/

相关文章:

mysql - 在 MySQL 中选择对同一临时表的不同列的计数

mysql - Perl MySQL 全文搜索

mysql - 如何在mySQL中同时选择和更新一条记录?

MYSQL - 拒绝具有特定权限的新用户访问 - MYSQL 错误 1045(28000)

php - PDO 的 AJAX 升级 ($qry_result)

sql - 我如何使用excel生成一个大的更新sql语句?

mysql - 使用 group by 或 distinct 时如何排序结果?

MySQL:让存储过程在警告时提前退出

php - MySQL 和 PHP |选择后更新不起作用

PHP & MySQL 更新查询只更新表中的最后一条记录