gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-29 19:29:13 24 4
gpt4 key购买 nike

这是我希望通过 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 [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] 的 OLD 值。

如果执行 UPDATE 语句 3 次,数据将正确计算出来。 [Calc A] 在第一次计算中设置正确,然后 [Calc B] 将在第二次 UPDATE 中引用 [Calc A] 的正确更新值,然后 [Calc C] 将在第二次 UPDATE 中引用 [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/41916780/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com