ここでは、UPDATE文で何を達成したいのかを表形式で示しています。MySQL - 前のSET文の結果に依存するSET文による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値を使用して計算し、データベースに書き込んだ新しい更新値は計算しません。これは、[Calc B]のOLD値を再度参照する[Calc C]に当てはまります。
UPDATEステートメントを3回実行すると、データが正しく計算されます。最初の計算で[Calc A]が正しく設定されていると、[Calc B]が2番目のUPDATEで[Calc A]の正しい更新値を参照し、[Calc C]が[Calc B]の正しい値を参照します3回目の更新。
私の質問は、どのようにすべての列を正しい値に設定するのですか?
MySQLまたはMicrosoft SQL Serverを使用していますか?角括弧を使用すると、Microsoftを使用していると思います。 –
@BillKarwin MySQLは、フィールド名のスペースのため角括弧しか使用していません – Josh