mysql下使用update s_MySQL-使用SET语句的UPDATE查询取决于前一个S...

这是我想通过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]将在第一个UPDATE上正确计算.但是,[Calc B]将使用[Calc A]中的OLD值而不是我刚刚写入数据库的NEW更新值来计算.这对[Calc C]仍然适用,它再次引用[Calc B]的OLD值.

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值