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

时间:2017-01-28 05:04:28

标签: 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]中的OLD值计算,而不是我刚刚写入数据库的NEW更新值。这适用于[Calc C],它再次引用[Calc B]的OLD值。

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

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

2 个答案:

答案 0 :(得分:3)

单独进行计算:

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

答案 1 :(得分:0)

我实际上在SET语句中使用局部变量找到了解决这个问题的方法。见下文。

UPDATE [EXAMPLE]
SET [Calc A]    = @calc_a : = A - B
    , [Calc B]  = @calc_b := @calc_a / D
    , [Calc C]  = B / @calc_b