次の方法で共有


ジョブ ステップでのトークンの使用

更新 : 2006 年 4 月 14 日

SQL Server エージェントを使用すると、Transact-SQL ジョブ ステップ スクリプトでトークンを使用できます。ジョブ ステップを記述するときにトークンを使用すると、ソフトウェア プログラムを記述するときの変数と同じような柔軟性が得られます。ジョブ ステップ スクリプトにトークンを挿入した後、Transact-SQL サブシステムでジョブ ステップが実行される前に、SQL Server エージェントにより実行時にトークンが置き換えられます。

ms175575.note(ja-jp,SQL.90).gif重要 :
SQL Server 2005 Service Pack 1 では、SQL Server エージェントのジョブ ステップ トークンの構文が変更されています。そのため、現在は、ジョブ ステップで使用されているすべてのトークンにエスケープ マクロを用意する必要があります。用意しなかった場合、ジョブ ステップは失敗します。エスケープ マクロの使用およびトークンを使用する SQL Server エージェントのジョブ ステップの更新については、「トークンの使用について」、「SQL Server エージェントのトークンとマクロ」、および「マクロを使用するジョブ ステップの更新」を参照してください。さらに、SQL Server エージェントのジョブ ステップ トークンの呼び出しに角かっこを使用していた SQL Server 2000 の構文 (たとえば、"[DATE]") も変更されました。現在、トークン名はかっこで囲み、トークンの構文の先頭にはドル記号 ($) を付ける必要があります。次に例を示します。 $(ESCAPE_macro name(DATE))

トークンの使用について

ms175575.security(ja-jp,SQL.90).gifセキュリティ メモ :
Windows イベント ログに対する書き込みアクセス許可のある Windows ユーザーは、SQL Server エージェント警告や WMI 警告によってアクティブ化されるジョブ ステップにアクセスできます。このセキュリティ上のリスクを回避するため、警告によってアクティブ化されるジョブ内での使用が可能な SQL Server エージェントのトークンは、既定では無効になっています。無効になっているトークンは、A-DBNA-SVRA-ERRA-SEVA-MSG、および WMI(property) です。 これらのトークンを使用する必要がある場合、信頼関係のある Windows セキュリティ グループ (Administrators グループなど) のメンバだけに、SQL Server が存在するコンピュータのイベント ログへの書き込み権限が許可されていることを、最初に確認してください。その後、オブジェクト エクスプローラで [SQL Server エージェント] を右クリックし、[プロパティ] をクリックします。次に、[警告システム] ページの [警告に応答するすべてのジョブのトークンを置き換える] チェック ボックスをオンにして、これらのトークンを有効にします。

SQL Server エージェントのトークンの置換は簡単で効率的です。SQL Server エージェントにより、トークンのリテラル文字列値にそのまま置き換えられます。すべてのトークンには大文字と小文字の区別があります。ジョブ ステップでは、この点を考慮し、使用するトークンを正しく引用したり、置換後の文字列を正しいデータ型に変換したりする必要があります。

たとえば、ジョブ ステップでデータベースの名前を表示するときに、次のステートメントを使用する場合があります。

PRINT N'Current database name is $(ESCAPE_SQUOTE(A-DBN))' ;

この例では、ESCAPE_SQUOTE マクロは A-DBN トークンと共に挿入されます。実行時に、A-DBN トークンは適切なデータベース名に置き換えられます。エスケープ マクロにより、トークンの置換後の文字列に誤って渡される可能性がある単一引用符がエスケープされます。SQL Server エージェントにより、最後の文字列にある 1 つの単一引用符が 2 つの連続する単一引用符に置き換えられます。

たとえば、トークンを置き換えるために渡される文字列が AdventureWorks'SELECT @@VERSION -- の場合、SQL Server エージェントのジョブ ステップで実行されるコマンドは次のようになります。

PRINT N'Current database name is AdventureWorks''SELECT @@VERSION --' ;

この場合、挿入されたステートメント SELECT @@VERSION は実行されません。代わりに、追加の単一引用符によって、サーバーは挿入されたステートメントを文字列として解析します。トークンの置換後の文字列に単一引用符が含まれていない場合は、エスケープされる文字はなく、トークンを含むジョブ ステップが意図したとおりに実行されます。

ジョブ ステップでのトークンの使用をデバッグするには、PRINT N'$(ESCAPE_SQUOTE(SQLDIR))' のような PRINT ステートメントを使用して、ジョブ ステップの出力をファイルまたはテーブルに保存します。[ジョブ ステップのプロパティ] ダイアログ ボックスの [詳細設定] ページを使用して、ジョブ ステップの出力ファイルまたは出力テーブルを指定します。

SQL Server エージェントのトークンとマクロ

次の表では、SQL Server エージェントでサポートされているトークンとマクロについて説明します。

SQL Server エージェントのトークン

トークン 説明

(A-DBN)

データベース名。ジョブが警告によって実行される場合、ジョブ ステップのこのトークンは自動的にデータベース名の値に置き換えられます。

(A-SVR)

サーバー名。ジョブが警告によって実行される場合、ジョブ ステップのこのトークンは自動的にサーバー名の値に置き換えられます。

(A-ERR)

エラー番号。ジョブが警告によって実行される場合、ジョブ ステップのこのトークンは自動的にエラー番号の値に置き換えられます。

(A-SEV)

エラーの重大度。ジョブが警告によって実行される場合、ジョブ ステップのこのトークンは自動的にエラー重大度の値に置き換えられます。

(A-MSG)

メッセージ テキスト。ジョブが警告によって実行される場合、ジョブ ステップのこのトークンは自動的にメッセージ テキストの値に置き換えられます。

(DATE)

YYYYMMDD 形式で表す現在の日付。

(INST)

インスタンス名。既定のインスタンスでは、このトークンは空です。

(JOBID)

ジョブ ID。

(MACH)

コンピュータ名。

(MSSA)

マスタ SQLServerAgent サービス名。

(OSCMD)

CmdExec ジョブ ステップの実行に使用されるプログラムのプレフィックス。

(SQLDIR)

SQL Server がインストールされているディレクトリ。特に指定しない限り、この値は C:\Program Files\Microsoft SQL Server\MSSQL です。

(STEPCT)

対象となるステップが実行された回数。ただし、再試行は除きます。ステップ コマンドでこの値を使用して、マルチステップ ループを強制終了させることができます。

(STEPID)

ステップ ID。

(SRVR)

SQL Server を実行しているコンピュータの名前。SQL Server インスタンスが名前付きインスタンスである場合は、これにインスタンス名が含まれます。

(TIME)

HHMMSS 形式で表す現在の時刻。

(STRTTM)

HHMMSS 形式で表すジョブの実行開始時刻。

(STRTDT)

YYYYMMDD 形式で表すジョブの実行開始日。

(WMI(property))

WMI 警告に応答して実行されるジョブの場合、property で指定したプロパティの値。たとえば、$(WMI(DatabaseName)) では、警告が実行される原因となった WMI イベントの DatabaseName プロパティの値が得られます。

SQL Server エージェントのエスケープ マクロ

エスケープ マクロ 説明

$(ESCAPE_SQUOTE(token_name))

トークンの置換後の文字列にある単一引用符 (') をエスケープします。1 つの単一引用符を 2 つの連続する単一引用符に置き換えます。

$(ESCAPE_DQUOTE(token_name))

トークンの置換後の文字列にある二重引用符 (") をエスケープします。1 つの二重引用符を 2 つの連続する二重引用符に置き換えます。

$(ESCAPE_RBRACKET(token_name))

トークンの置換後の文字列にある右角かっこ (]) をエスケープします。1 つの右角かっこを 2 つの連続する右角かっこに置き換えます。

$(ESCAPE_NONE(token_name))

文字列内の文字をエスケープせずにトークンを置き換えます。このマクロは、トークンの置換後の文字列を信頼されたユーザーのみが必要としている環境で、旧バージョンとの互換性をサポートするために用意されています。詳細については、このトピックの「マクロを使用するジョブ ステップの更新」を参照してください。

マクロを使用するジョブ ステップの更新

SQL Server 2005 Service Pack 1 では、エスケープ マクロを伴わないトークンを含むジョブ ステップは失敗し、エラー メッセージが返されます。このエラー メッセージは、ジョブを実行する前にマクロで更新する必要のあるトークンがジョブ ステップに 1 つ以上含まれていることを示します。

サポート技術情報の資料「SQL Server 2005 Service Pack 1 をインストールした後に、トークンを使用するジョブ ステップがジョブに含まれる場合、SQL Server エージェント ジョブが失敗します。」に記載されているスクリプトを使用すると、ESCAPE_NONE マクロを含むトークンを使用するすべてのジョブ ステップを更新できます。このスクリプトを使用した後、トークンを使用するジョブ ステップをできるだけ早く確認し、ESCAPE_NONE マクロを、ジョブ ステップのコンテキストに適したエスケープ マクロに置き換えることをお勧めします。

次の表では、SQL Server 2005 Service Pack 1 の SQL Server エージェントでトークンの置換がどのように処理されるのかを説明します。警告トークンの置換の有効と無効を切り替えるには、オブジェクト エクスプローラで [SQL Server エージェント] を右クリックし、[プロパティ] をクリックします。次に、[警告システム] ページの [警告に応答するすべてのジョブのトークンを置き換える] チェック ボックスをオンまたはオフにします。

トークンの構文 警告トークンの置換が有効な場合 警告トークンの置換が無効な場合

ESCAPE マクロを使用する

ジョブ内のすべてのトークンが正常に置き換えられます。

警告によってアクティブ化されるトークンは置き換えられません。このようなトークンには、A-DBNA-SVRA-ERRA-SEVA-MSG、および WMI(property) があります。他の静的なトークンは正常に置き換えられます。

ESCAPE マクロを使用しない

トークンを含んでいるすべてのジョブが失敗します。

トークンを含んでいるすべてのジョブが失敗します。

トークンの構文の更新例

A. 入れ子になっていない文字列でトークンを使用する

次の例では、適切なエスケープ マクロを使用して入れ子になっていない単純なスクリプトを更新する方法を示します。更新スクリプトを実行する前に、次のジョブ ステップ スクリプトで、ジョブ ステップ トークンを使用して適切なデータベース名を表示します。

PRINT N'Current database name is $(A-DBN)' ;

更新スクリプトを実行すると、ESCAPE_NONE マクロが A-DBN トークンの前に挿入されます。表示する文字列を区切るために単一引用符が使用されているため、次のように、ESCAPE_SQUOTE マクロを挿入してジョブ ステップを更新する必要があります。

PRINT N'Current database name is $(ESCAPE_SQUOTE(A-DBN))' ;

B. 入れ子になっている文字列でトークンを使用する

トークンが入れ子になっている文字列やステートメントで使用されているジョブ ステップ スクリプトでは、入れ子になっているステートメントを複数のステートメントに書き直してから、適切なエスケープ マクロを挿入する必要があります。

たとえば、次のジョブ ステップを考えてみましょう。A-MSG トークンを使用するこのジョブ ステップは、エスケープ マクロで更新されていません。

PRINT N'Print ''$(A-MSG)''' ;

更新スクリプトを実行すると、ESCAPE_NONE マクロがトークンと共に挿入されます。ただし、この場合、次のように入れ子を使用しないスクリプトに書き直して ESCAPE_SQUOTE マクロを挿入し、トークンの置換後の文字列に渡される可能性がある区切り文字を正しくエスケープすることが必要な場合があります。

DECLARE @msgString nvarchar(max)

SET @msgString = '$(ESCAPE_SQUOTE(A-MSG))'

SET @msgString = QUOTENAME(@msgString,'''')

PRINT N'Print ' + @msgString ;

また、この例では、QUOTENAME 関数によって引用符が設定されることにも注意してください。

C. ESCAPE_NONE マクロと共にトークンを使用する

次の例は、あるスクリプトの一部です。ここでは、sysjobs テーブルから job_id を取得し、スクリプト内で既にバイナリ データ型として宣言された @JobID 変数を設定するために JOBID トークンを使用しています。バイナリ データ型には区切り文字が不要なので、ESCAPE_NONE マクロは JOBID トークンと共に使用されることに注意してください。更新スクリプトの実行後、このジョブ ステップを更新する必要はありません。

SELECT * FROM msdb.dbo.sysjobs

WHERE @JobID = CONVERT(uniqueidentifier, $(ESCAPE_NONE(JOBID))) ;

参照

その他の技術情報

sp_add_jobstep (Transact-SQL)

ヘルプおよび情報

SQL Server 2005 の参考資料の入手

変更履歴

リリース 履歴

2006 年 4 月 14 日

新しい内容 :
  • SQL Server 2005 Service Pack 1 でトークンの構文が変更されたことについての情報を追加しました。この変更により、トークンを使用するすべてのジョブ ステップにエスケープ マクロを挿入する必要があります。