例外表のメッセージ列の構造は、 前述の制約の名前、長さ、および区切り文字を連結したリストです。 この情報についての照会を作成したい場合があるかもしれません。
たとえば、すべての違反のリストを作成し、 各行ごとにその制約名だけを示すための照会を作成してみましょう。 元の表 T1 に 2 つの列 C1 および C2 があるとします。 また、対応する例外表 E1 には、T1 内のそれらの列に対応する列 C1 および C2 と、 メッセージ列としての MSGCOL があるとします。 以下の照会では再帰を使っており、 行ごとに 1 つの制約名を示します (複数の違反については行を反復します)。
WITH IV (C1, C2, MSGCOL, CONSTNAME, I, J) AS (SELECT C1, C2, MSGCOL, CHAR(SUBSTR(MSGCOL, 12, INTEGER(DECIMAL(VARCHAR(SUBSTR(MSGCOL,7,5)),5,0)))), 1, 15+INTEGER(DECIMAL(VARCHAR(SUBSTR(MSGCOL,7,5)),5,0)) FROM E1 UNION ALL SELECT C1, C2, MSGCOL, CHAR(SUBSTR(MSGCOL, J+6, INTEGER(DECIMAL(VARCHAR(SUBSTR(MSGCOL,J+1,5)),5,0)))), I+1, J+9+INTEGER(DECIMAL(VARCHAR(SUBSTR(MSGCOL,J+1,5)),5,0)) FROM IV WHERE I < INTEGER(DECIMAL(VARCHAR(SUBSTR(MSGCOL,1,5)),5,0)) ) SELECT C1, C2, CONSTNAME FROM IV;
特定の制約に違反したすべての行のリストを作成したい場合は、 次のようにしてこの照会を拡張します。
WITH IV (C1, C2, MSGCOL, CONSTNAME, I, J) AS (SELECT C1, C2, MSGCOL, CHAR(SUBSTR(MSGCOL, 12, INTEGER(DECIMAL(VARCHAR(SUBSTR(MSGCOL,7,5)),5,0)))), 1, 15+INTEGER(DECIMAL(VARCHAR(SUBSTR(MSGCOL,7,5)),5,0)) FROM E1 UNION ALL SELECT C1, C2, MSGCOL, CHAR(SUBSTR(MSGCOL, J+6, INTEGER(DECIMAL(VARCHAR(SUBSTR(MSGCOL,J+1,5)),5,0)))), I+1, J+9+INTEGER(DECIMAL(VARCHAR(SUBSTR(MSGCOL,J+1,5)),5,0)) FROM IV WHERE I < INTEGER(DECIMAL(VARCHAR(SUBSTR(MSGCOL,1,5)),5,0)) ) SELECT C1, C2, CONSTNAME FROM IV WHERE CONSTNAME = 'constraintname';
検査制約のすべての違反のリストを作成するには、以下のものを実行します。
WITH IV (C1, C2, MSGCOL, CONSTNAME, CONSTTYPE, I, J) AS (SELECT C1, C2, MSGCOL, CHAR(SUBSTR(MSGCOL, 12, INTEGER(DECIMAL(VARCHAR(SUBSTR(MSGCOL,7,5)),5,0)))), CHAR(SUBSTR(MSGCOL, 6, 1)), 1, 15+INTEGER(DECIMAL(VARCHAR(SUBSTR(MSGCOL,7,5)),5,0)) FROM E1 UNION ALL SELECT C1, C2, MSGCOL, CHAR(SUBSTR(MSGCOL, J+6, INTEGER(DECIMAL(VARCHAR(SUBSTR(MSGCOL,J+1,5)),5,0)))), CHAR(SUBSTR(MSGCOL, J, 1)), I+1, J+9+INTEGER(DECIMAL(VARCHAR(SUBSTR(MSGCOL,J+1,5)),5,0)) FROM IV WHERE I < INTEGER(DECIMAL(VARCHAR(SUBSTR(MSGCOL,1,5)),5,0)) ) SELECT C1, C2, CONSTNAME FROM IV WHERE CONSTTYPE = 'K';