SQL質疑応答スレ 9問目
at DB
377:NAME IS NULL
09/12/26 19:04:21 dwahwS+t
oracle 10gのUPDATE文で質問です。
Aテーブル
aaa|ddd
Bテーブル
aaa|bbb
Cテーブル
bbb|ccc
Aテーブルに対して、カラムaaaでBテーブルが紐づき、
Bテーブルに対して、カラムbbbでCテーブルが紐づくとします。
(つまり、Aテーブルのレコード1件は、Bテーブルを経由してCテーブルのレコード1件と紐づく)
ここで、A.ddd = 'X'のとき、C.ccc = 'Y'に更新したいのですが
下記の文であってますでしょうか?
また、もっと効率のいい方法はありますでしょうか?
update C set C.ccc = 'Y' where C.bbb in
( select B.bbb from B where B.aaa in
( select A.aaa from A where A.ddd = 'X')
)
次ページ最新レス表示スレッドの検索類似スレ一覧話題のニュースおまかせリスト▼オプションを表示暇つぶし2ch
4765日前に更新/307 KB
担当:undef