Hitachi

ノンストップデータベース HiRDB Version 10 SQLリファレンス


3.6.1 ALTER TRIGGERの形式と規則

〈この項の構成〉

(1) 機能

トリガのSQLオブジェクトを再作成します。

(2) 使用権限

トリガの所有者

自分が所有するトリガのSQLオブジェクトを再作成できます。

DBA権限を持つユーザ

自分が所有するトリガと,他ユーザが所有するトリガのSQLオブジェクトを再作成できます。

(3) 形式

 ALTER TRIGGER 〔認可識別子.〕トリガ識別子
   {CHANGE|ALTER} ROUTINE OBJECT
   〔SQLコンパイルオプション〔SQLコンパイルオプション〕…〕
 
 SQLコンパイルオプション::={ISOLATION データ保証レベル 〔FOR UPDATE {EXCLUSIVE|COMPATIBLE}〕
                |OPTIMIZE LEVEL SQL最適化オプション
                         〔,SQL最適化オプション〕…
                |ADD OPTIMIZE LEVEL SQL拡張最適化オプション
                         〔,SQL拡張最適化オプション〕…
                |SUBSTR LENGTH 文字の最大長 }

(4) オペランド

(a) 〔認可識別子.〕トリガ識別子

認可識別子

SQLオブジェクトを再作成するトリガの所有者の認可識別子を指定します。省略した場合,ALTER TRIGGERを実行するユーザの認可識別子が仮定されます。

トリガ識別子

SQLオブジェクトを再作成するトリガの識別子を指定します。

(b) {CHANGE|ALTER} ROUTINE OBJECT

トリガを再作成することを示します。CHANGE及びALTERは,どちらを指定しても意味は変わりません。

(c) SQLコンパイルオプション

::={ISOLATION データ保証レベル 〔FOR UPDATE {EXCLUSIVE|COMPATIBLE}〕
    |OPTIMIZE LEVEL SQL最適化オプション〔,SQL最適化オプション〕…
    |ADD OPTIMIZE LEVEL SQL拡張最適化オプション〔,SQL拡張最適化オプション〕…
    |SUBSTR LENGTH 文字の最大長 }

SQLコンパイルオプションにはISOLATION,OPTIMIZE LEVEL,ADD OPTIMIZE LEVEL,SUBSTR LENGTHをそれぞれ1回しか指定できません。

〔ISOLATION データ保証レベル 〔FOR UPDATE {EXCLUSIVE|COMPATIBLE}〕〕

SQLのデータ保証レベルを指定します。

データ保証レベル

データ保証レベルとは,トランザクションのどの時点までデータの内容を保証するかのレベルです。次に示すデータ保証レベルを指定できます。

  • 0

    データの内容を保証しない場合に指定します。

    0レベルを指定すると,ほかのユーザが更新中のデータでも,更新完了を待たないで参照できます。ただし,参照する表が共用表の場合,ほかのユーザが排他モードでLOCK文を実行しているときには,排他解除待ちとなります。

  • 1

    検索処理の終了までデータの内容を保証したい場合に指定します。

    1レベルを指定すると,検索処理が終了するまで(HiRDBがページ,又は行を見終わるまで)一度検索したデータをほかのユーザは更新できません。

  • 2

    トランザクションの終了まで一度検索したデータの内容を保証したい場合に指定します。

    2レベルを指定すると,トランザクションが終了するまで一度検索したデータをほかのユーザは更新できません。

〔FOR UPDATE {EXCLUSIVE|COMPATIBLE}〕

トリガ中で,FOR UPDATE句を指定した(FOR UPDATEが仮定される場合を含む)カーソル又は問合せに対して,SQLコンパイルオプションで指定したデータ保証レベルに関係なく,常にWITH EXCLUSIVE LOCKを仮定する場合に指定します。

このオペランドを省略した場合,EXCLUSIVEを仮定します。ただし,0904互換モードを適用している場合はCOMPATIBLEを仮定します。

バージョン09-50より前のHiRDBでFOR UPDATE EXCLUSIVEを省略したトリガと同じ動作をさせたい場合はCOMPATIBLEを指定します。

このオペランドと,ISOLATIONデータ保証レベルの関係から決まるFOR UPDATEの排他オプションを次に示します。

ISOLATION データ保証レベル

FOR UPDATE EXCLUSVIE

FOR UPDATE COMPATIBLE

0

WITH EXCLUSIVE LOCK

WITHOUT LOCK WAIT

1

WITH EXCLUSIVE LOCK

WITHOUT LOCK WAIT

2

WITH EXCLUSIVE LOCK

WITH EXCLUSIVE LOCK

《クライアント環境定義との関係》

ALTER TRIGGERに対して,PDISLLVL,PDFORUPDATEEXLOCKの指定は無効となります。

《SQLとの関係》

トリガ中のSQL文に排他オプションを指定している場合は,SQLコンパイルオプションで指定するデータ保証レベル,FOR UPDATE EXCLUSIVE,及びFOR UPDATE COMPATIBLEから仮定する排他オプションよりSQL文に指定した排他オプションが優先されます。

《システム定義との関係》

ALTER TRIGGERに対して,pd_isolation_levelオペランドの指定は無効となります。

このオペランドを省略した場合,前回のSQLオブジェクト作成時(CREATE TRIGGER,ALTER TRIGGER,又はALTER ROUTINEの実行時)に指定した値が仮定されます。

データ保証レベルについては,マニュアル「HiRDB UAP開発ガイド」を参照してください。

〔OPTIMIZE LEVEL SQL最適化オプション〔,SQL最適化オプション〕…〕

データベースの状態を考慮して,最も効率的なアクセスパスを決定するための最適化の方法を指定します。

SQL最適化オプションの指定値及びその内容については,マニュアル「HiRDB UAP開発ガイド」の「PDSQLOPTLVL」を参照してください。

SQL最適化オプションは,識別子(文字列)で指定する方法と,数値で指定する方法がありますが,通常時は識別子で指定する方法をお勧めします。

省略した場合,前回のSQLオブジェクト作成時(CREATE TRIGGER,ALTER TRIGGER,又はALTER ROUTINE)に採用した値が仮定されます。

識別子で指定する場合:
OPTIMIZE LEVEL "識別子"〔,"識別子"〕…

<指定例>

  • ネストループジョイン優先とグループ分け高速化処理を適用する場合

    OPTIMIZE LEVEL "PRIOR_NEST_JOIN","RAPID_GROUPING"

  • すべての最適化を適用しない場合

    OPTIMIZE LEVEL "NONE"

<規則>

  1. 識別子は一つ以上指定してください。

  2. 識別子を二つ以上指定する場合は,コンマ(,)で区切ってください。

  3. すべての最適化を適用しない場合は,識別子に"NONE"を指定してください。ただし,同時に"NONE"以外の識別子を指定すると,"NONE"は無効になります。

  4. 識別子は大文字及び小文字で指定できます。

  5. 同じ識別子を二つ以上指定しても,一つ指定したものとみなされますが,なるべく同じ識別子は指定しないようにしてください。

数値で指定する場合:
OPTIMIZE LEVEL 符号なし整数〔,符号なし整数〕…

<指定例>

  • 複数のSQLオブジェクト作成,ANDの複数インデクス利用の抑止,及び複数インデクス利用の強制を適用する場合

    符号なし整数をコンマで区切って指定する場合:

    OPTIMIZE LEVEL 4,10,16

    符号なし整数の和を指定する場合:

    OPTIMIZE LEVEL 30

  • 既に14(4+10)を指定していて,新たに16を追加する場合

    OPTIMIZE LEVEL 14,16

  • すべての最適化を適用しない場合

    OPTIMIZE LEVEL 0

<規則>

  1. バージョン06-00より前のHiRDBから,バージョン06-00以降のHiRDBにバージョンアップする場合,バージョン06-00より前の合計値指定も有効となります。最適化オプションを変更する必要がない場合は,バージョン06-00以降のHiRDBにバージョンアップしたときにこのオペランドの指定値を変更する必要はありません。

  2. 符号なし整数は一つ以上指定してください。

  3. 符号なし整数を二つ以上指定する場合は,コンマ(,)で区切ってください。

  4. すべての最適化を適用しない場合は,符号なし整数に0を指定してください。ただし,同時に0以外の識別子を指定すると,0は無効になります。

  5. 同じ符号なし整数を二つ以上指定しても,一つ指定したものとみなされますが,なるべく同じ符号なし整数は指定しないようにしてください。

  6. 複数の最適化方法を指定する場合,その符号なし整数の和を指定することもできます。ただし,同じ最適化方法の値は二つ以上足さないでください(足した結果が別の最適化方法とみなされることもあるため)。

  7. 複数の最適化方法の値を足して指定する場合,どの最適方法を指定しているのか分かりにくくなるため,コンマで区切って指定する方法をお勧めします。また,既に複数の最適化方法の値を足して指定している場合で,新たに別の最適化方法が必要になったときは,追加する値をコンマで区切って後ろに指定できます。

《システム定義との関係》
  1. ALTER TRIGGERに対して,システム定義のpd_optimize_levelオぺランドの指定は無効となります。

  2. システム定義のpd_floatable_besオペランド,又はpd_non_floatable_besオペランドを指定している場合,「フロータブルサーバ対象拡大(データ取り出しバックエンドサーバ)」及び「フロータブルサーバ対象限定(データ取り出しバックエンドサーバ)」の指定は無効となります。

  3. システム定義のpd_indexlock_modeオペランドにKEYを指定している場合(インデクスキー値排他の場合),「更新SQLの作業表作成抑止」の指定は無効になります。

《クライアント環境定義との関係》

ALTER TRIGGERに対して,PDSQLOPTLVLの指定は無効となります。

《SQLとの関係》

SQL文中にSQL最適化指定を指定している場合は,SQL最適化オプションよりもSQL最適化指定が優先されます。SQL最適化指定については,「SQL最適化指定」を参照してください。

〔ADD OPTIMIZE LEVEL SQL拡張最適化オプション〔,SQL拡張最適化オプション〕…〕

データベースの状態を考慮して,最も効率的なアクセスパスを決定するための最適化の方法を指定します。

SQL拡張最適化オプションの指定値及びその内容については,マニュアル「HiRDB UAP開発ガイド」の「PDADDITIONALOPTLVL」を参照してください。

SQL拡張最適化オプションは,識別子(文字列)で指定する方法と,数値で指定する方法があります。

省略した場合,前回のSQLオブジェクト作成時(CREATE TRIGGER,ALTER TRIGGER,又はALTER ROUTINE)に採用した値が仮定されます。

識別子で指定する場合:
ADD OPTIMIZE LEVEL "識別子"〔,"識別子"〕…

<指定例>

  • 「コストベース最適化モード2の適用」及び「ハッシュジョイン,副問合せのハッシュ実行」を適用する場合

    ADD OPTIMIZE LEVEL "COST_BASE_2","APPLY_HASH_JOIN"

  • すべての最適化を適用しない場合

    ADD OPTIMIZE LEVEL "NONE"

<規則>

  1. 識別子は一つ以上指定してください。

  2. 識別子を二つ以上指定する場合は,コンマ(,)で区切ってください。

  3. すべての最適化を適用しない場合は,識別子に"NONE"を指定してください。

  4. 識別子は大文字及び小文字で指定できます。

  5. 同じ識別子を二つ以上指定しても,一つ指定したものとみなされますが,なるべく同じ識別子は指定しないようにしてください。

数値で指定する場合:
ADD OPTIMIZE LEVEL 符号なし整数〔,符号なし整数〕…

<指定例>

  • 「コストベース最適化モード2の適用」及び「ハッシュジョイン,副問合せのハッシュ実行」を適用する場合

    ADD OPTIMIZE LEVEL 1,2

  • すべての最適化を適用しない場合

    ADD OPTIMIZE LEVEL 0

<規則>

  1. 符号なし整数は一つ以上指定してください。

  2. 符号なし整数を二つ以上指定する場合は,コンマ(,)で区切ってください。

  3. すべての最適化を適用しない場合は,符号なし整数に0を指定してください。

  4. 同じ符号なし整数を二つ以上指定しても,一つ指定したものとみなされますが,なるべく同じ符号なし整数は指定しないようにしてください。

《システム定義との関係》

ALTER TRIGGERに対して,システム定義のpd_optimize_levelオぺランドの指定は無効となります。

《クライアント環境定義との関係》

ALTER TRIGGERに対して,PDADDITIONALOPTLVLの指定は無効となります。

《SQLとの関係》

SQL文中にSQL最適化指定を指定している場合は,SQL最適化オプションよりもSQL最適化指定が優先されます。SQL最適化指定については,「SQL最適化指定」を参照してください。

〔SUBSTR LENGTH 文字の最大長〕

1文字を表現する最大バイト数を指定します。

文字の最大長に指定できる値は,3〜6(pdntenvコマンド(UNIX版の場合はpdsetupコマンド)で文字コード種別にutf-8_ivsを指定した場合は3〜10)です。

pdntenvコマンド(UNIX版の場合はpdsetupコマンド)で文字コード種別にutf-8,又はutf-8_ivsを指定した場合にだけ有効となり,スカラ関数SUBSTRの結果の長さに影響します。SUBSTRについては,「SUBSTR」を参照してください。

<規則>

バージョン08-00より前のHiRDBからバージョン08-00以降のHiRDBにバージョンアップする場合,3を仮定します。文字の最大長を変更する必要がない場合は,バージョン08-00以降のHiRDBにバージョンアップしたときにこのオペランドを指定する必要はありません。

《システム定義との関係》

ALTER TRIGGERに対して,システム定義のpd_substr_lengthオぺランドの指定は無効となります。pd_substr_lengthオぺランドについては,マニュアル「HiRDB システム定義」を参照してください。

《クライアント環境定義との関係》

ALTER TRIGGERに対して,PDSUBSTRLENの指定は無効となります。PDSUBSTRLENについては,マニュアル「HiRDB UAP開発ガイド」を参照してください。

《pdntenvコマンド又はpdsetupコマンドで指定した文字コード種別との関係》

文字コード種別にutf-8,又はutf-8_ivsを指定した場合だけ有効となります。

そのほかの文字コード種別の場合は,構文チェックだけ行い,指定を無視します。

このオペランドを省略した場合,前回のSQLオブジェクト作成時(CREATE TRIGGER,ALTER TRIGGER,又はALTER ROUTINEの実行時)に指定した値が仮定されます。

(5) 共通規則

  1. SQLオブジェクトが無効なトリガに対して,ALTER TRIGGERを実行して正常に終了すると,そのトリガのSQLオブジェクトは有効になります。

  2. SQLオブジェクトがインデクス無効状態になっているトリガに対して,ALTER TRIGGERを実行して正常に終了すると,トリガのSQLオブジェクトのインデクス無効状態は解除されます。SQLオブジェクトがインデクス無効状態のトリガは,実行時にエラーになります。

  3. ALTER TRIGGERでSQLコンパイルオプションを指定する場合,再作成するトリガの元のCREATE TRIGGERにSQLコンパイルオプションを反映してできるSQL文は,SQL文の最大長を超えないようにしてください。

  4. 次の条件では,Java手続きからALTER TRIGGERを実行できません。

    • 実行中のSQLオブジェクトが再作成になる場合

(6) 留意事項

  1. ALTER TRIGGERは,OLTP下のX/Openに従ったUAPから指定できません。

  2. ALTER TRIGGER実行直後にGET DIAGNOSTICS文を実行すると,ALTER TRIGGERの診断情報が取得できます。このとき,再作成が正常終了したトリガのSQLコードは0となります。

  3. トリガ中のトリガSQL文のデータ保証レベル,SQL最適化オプション,SQL拡張最適化オプション,及び文字の最大長は,トリガの定義時,又は変更時の指定で決まり,トリガ動作実行時のシステム定義やクライアント環境定義の影響を受けません。

(7) 使用例

  1. 無効になったトリガ(TRIG1)のSQLオブジェクトを再作成します。

      ALTER TRIGGER TRIG1
          CHANGE ROUTINE OBJECT