例: WHERE句の相関サブクエリーを使ったUPDATE - Advanced SQL Engine - Teradata Database

Teradata Vantage™ - SQLデータ操作言語

Product
Advanced SQL Engine
Teradata Database
Release Number
17.05
Published
2021年1月
Language
日本語
Last Update
2021-03-30
dita:mapPath
ja-JP/vnq1596660420420.ditamap
dita:ditavalPath
ja-JP/vnq1596660420420.ditaval
dita:id
B035-1146
Product Category
Software
Teradata Vantage

非相関サブクエリーにするには、サブクエリーを変更して、参照するすべてのテーブルを内部のFROM句に含めます。

     UPDATE publisher
     SET pubnum = NULL
     WHERE 0 = (SELECT COUNT(*)
                FROM book, publisher
                WHERE book.pubnum = publisher.pubnum);

リクエストには相関subqueryが含まれておらず、subquery内の条件にはローカルに定義された参照があります。カウントは1回で確定され、値がゼロにはならないため、行は削除されません。

相関サブクエリーと非相関サブクエリーの追加例については、相関subqueryを参照してください。