文書番号: 64238 - 最終更新日: 2011年7月7日 - リビジョン: 5.0

PRB: 更新トリガーがない行を変更した場合

お知らせお使いのオペレーティング システムには適用しない情報が含まれている場合があります。

目次

すべて展開する | すべて折りたたむ

現象

トリガーと UPDATE(ColName) 句を使用して定義されています。列を更新しようとするとしても、更新ステートメントは実際には影響はありません内のステートメントのすべての行を更新プログラムをブロックした場合に実行されます。更新プログラムに対してのみ true を指定する必要がある場合実際にクエリを更新する列です。ただし、その場合 true を返します更新された行はありません。

原因

T SQL への参照は指定した列が変更されているかどうかをテストするのには IF UPDATE を使用することを示しています。Update ステートメントで指定した列が含まれている場合に、IF UPDATE は true を返します。INSERT または UPDATE ステートメントが実行されると、「を挿入します」と呼ばれる特別なテーブルに、影響を受ける行が追加されます。

回避策

行を追加することで
   and (select count(*) from inserted) > 0
				

IF UPDATE 句のすぐ後、トリガーのみ呼び出される1 つ以上の行が実際に変更されたとき。SQL スクリプトを次に示しますこの実装方法を示しています。

詳細

トリガーを使用する場合は、スクリプトの更新

   use pubs
   go

   create table testtable
   (col1   int,
    col2   int,
    col3   int)
   go

   insert into testtable values( 5, 0, 0)
   insert into testtable values(10, 0, 0)
   insert into testtable values(15, 0, 0)
   insert into testtable values(20, 0, 0)
   go

   create trigger t1
   on testtable
   for update as
   if update(col2)
   and (select count(*) from inserted) > 0
   begin
   print "Trigger t1 has detected an update of col2"
   update testtable
   set col3 = col3 + 10
   end
   go

   select * from testtable
   go

   update testtable
   set col2 = col2 + 1
   where col1 > 0
   go

   select *  from testtable
   go

   update testtable
   set col2 = col2 + 1
   where col1 > 10
   go

   select *  from testtable
   go

   update testtable
   set col2 = col2 + 1
   where col1 > 20
   go

   select *  from testtable
   go

   drop table testtable
   go
				

この資料は以下の製品について記述したものです。
  • Microsoft SQL Server 4.21a Standard Edition
  • Microsoft SQL Server 6.0 Standard Edition
  • Microsoft SQL Server 6.5 Standard Edition
  • Microsoft SQL Server 7.0 Standard Edition
  • Microsoft SQL Server 2000 Standard Edition
キーワード:?
kbother kbmt KB64238 KbMtja
機械翻訳機械翻訳
重要: このサポート技術情報 (以下「KB」) は、翻訳者による翻訳の代わりに、マイクロソフト機械翻訳システムによって翻訳されたものです。マイクロソフトは、お客様に、マイクロソフトが提供している全ての KB を日本語でご利用いただけるように、翻訳者による翻訳 KB に加え機械翻訳 KB も提供しています。しかしながら、機械翻訳の品質は翻訳者による翻訳ほど十分ではありません。誤訳や、文法、言葉使い、その他、たとえば日本語を母国語としない方が日本語を話すときに間違えるようなミスを含んでいる可能性があります。マイクロソフトは、機械翻訳の品質、及び KB の内容の誤訳やお客様が KB を利用されたことによって生じた直接または間接的な問題や損害については、いかなる責任も負わないものとします。マイクロソフトは、機械翻訳システムの改善を継続的に行っています。
英語版 KB:64238? (http://support.microsoft.com/kb/64238/en-us/ )
"Microsoft Knowledge Baseに含まれている情報は、いかなる保証もない現状ベースで提供されるものです。Microsoft Corporation及びその関連会社は、市場性および特定の目的への適合性を含めて、明示的にも黙示的にも、一切の保証をいたしません。さらに、Microsoft Corporation及びその関連会社は、本文書に含まれている情報の使用及び使用結果につき、正確性、真実性等、いかなる表明・保証も行ないません。Microsoft Corporation、その関連会社及びこれらの権限ある代理人による口頭または書面による一切の情報提供またはアドバイスは、保証を意味するものではなく、かつ上記免責条項の範囲を狭めるものではありません。Microsoft Corporation、その関連会社 及びこれらの者の供給者は、直接的、間接的、偶発的、結果的損害、逸失利益、懲罰的損害、または特別損害を含む全ての損害に対して、状況のいかんを問わず一切責任を負いません。(Microsoft Corporation、その関連会社 またはこれらの者の供給者がかかる損害の発生可能性を了知している場合を含みます。) 結果的損害または偶発的損害に対する責任の免除または制限を認めていない地域においては、上記制限が適用されない場合があります。なお、本文書においては、文書の体裁上の都合により製品名の表記において商標登録表示、その他の商標表示を省略している場合がありますので、予めご了解ください。"