4

そのIDに関連するすべての金額テーブル2の合計が(fk_idを介して)= 0の場合、テーブル1の列dateの日付フィールドを「10/11/2012」と設定しようとしています。意味は次のとおりです。

から:

表1

    id    date
    1     10/11/2011
    2      
    3     10/12/2011

表2

    fk_id    amount
    1     200
    2     0
    2     0
    3     100

に:

表1

    id    date
    1     10/11/2011
    2     10/11/2012
    3     10/12/2011

表2

    fk_id    amount
    1     200
    2     0
    2     0
    3     100

これは私が現在持っているものです:

update table1
set date = '10/11/2012
FROM table1 inner join table 2 on table1.id = table2.fk_id
HAVING sum(table2.amount) = 0

誰かがここで私を助けてくれますか?

4

2 に答える 2

5
UPDATE table1 
SET date = '10/11/2012' 
FROM table1 
WHERE id IN (SELECT FK_ID FROM table2 GROUP BY FK_ID HAVING SUM(Amount)=0)
于 2012-08-31T19:38:30.733 に答える
0

これは機能するはずです:

UPDATE T1
SET [date] = '20121011'
FROM table1 T1
INNER JOIN (SELECT fk_id, SUM(amount) Amount
            FROM table2
            GROUP BY fk_id
            HAVING SUM(amount) = 0) T2
ON T1.id = T2.fk_id
于 2012-08-31T19:39:00.543 に答える