エラー処理 (XQuery)
適用対象: SQL Server
W3C 仕様では、型エラーを静的または動的に発生させ、静的、動的、および型エラーを定義します。
コンパイルとエラー処理
XQuery 式や XML DML ステートメントの構文が誤っている場合は、コンパイル エラーが返されます。 コンパイル フェーズでは、XQuery 式と DML ステートメントの静的な型の正確性がチェックされ、型指定された XML の型推論に XML スキーマが使用されます。 型の安全性違反により実行時に式が失敗する可能性がある場合は、静的な型エラーが発生します。 静的なエラーの例には、整数への文字列の追加、存在しないノードに対する型指定されたデータのクエリの実行などがあります。
W3C 標準からの逸脱として、XQuery ランタイム エラーは空のシーケンスに変換されます。 この空のシーケンスは、呼び出し時の状況に応じ、空の XML または NULL としてクエリの結果に反映される場合があります。
正しい型に明示的にキャストすると、ユーザーは静的エラーを回避できますが、実行時キャスト エラーは空のシーケンスに変換されます。
静的エラー
静的エラーは、Transact-SQL エラー メカニズムを使用して返されます。 SQL Server では、XQuery 型エラーは静的に返されます。 詳細については、「 XQuery と静的な型指定」を参照してください。
動的エラー
XQuery では、ほとんどの動的エラーが空のシーケンス ("()") にマップされます。 ただし、XQuery アグリゲーター関数のオーバーフロー条件と XML-DML 検証エラーという 2 つの例外があります。 ほとんどの動的エラーは空のシーケンスにマップされることに注意してください。 そうしないと、XML インデックスを利用するクエリ実行によって、予期しないエラーが発生する可能性があります。 そのため、予期しないエラーを生成せずに効率的な実行を実現するために、SQL Server データベース エンジンは動的エラーを () にマップします。
多くの場合、述語内で動的エラーが発生する状況では、() が False にマップされるため、エラーを発生させてもセマンティクスは変更されません。 ただし、動的エラーではなく () を返すと予期しない結果が生じることがあります。 これを示す例を次に示します。
例: 文字列で avg() 関数を使用する
次の例では、 avg 関数 を呼び出して、3 つの値の平均を計算します。 これらの値の 1 つは文字列です。 この場合の XML インスタンスは型指定されていないため、その中のすべてのデータは型指定されていないアトミック型になります。 avg()関数は、平均を計算する前に、まずこれらの値を xs:double にキャストします。 ただし、 "Hello"
値を xs:double にキャストできず、動的エラーが発生します。 この場合、動的エラーを返す代わりに、 "Hello"
を xs:double にキャストすると、空のシーケンスが発生します。 avg()関数は、この値を無視し、他の 2 つの値の平均を計算し、150 を返します。
DECLARE @x xml
SET @x=N'<root xmlns:myNS="test">
<a>100</a>
<b>200</b>
<c>Hello</c>
</root>'
SELECT @x.query('avg(//*)')
例: not 関数の使用
述語で not 関数 を使用すると (たとえば、 /SomeNode[not(Expression)]
)、式によって動的エラーが発生すると、エラーの代わりに空のシーケンスが返されます。 not()を空のシーケンスに適用すると、エラーではなく True が返されます。
例: 文字列のキャスト
次の例では、リテラル文字列 "NaN" が xs:string にキャストされ、次に xs:double にキャストされます。 その結果、空の行セットが返されます。 文字列 "NaN" は xs:double に正しくキャストすることはできません。ただし、この文字列は最初に xs:string にキャストされているため、このことは実行時まで判断できません。
DECLARE @x XML
SET @x = ''
SELECT @x.query(' xs:double(xs:string("NaN")) ')
GO
ただし、この例では静的な型エラーが発生します。
DECLARE @x XML
SET @x = ''
SELECT @x.query(' xs:double("NaN") ')
GO
実装の制限事項
fn:error()関数はサポートされていません。