WHERE句などでのNULL値との比較も必ずFALSEが返ります。
ANSI_NULLSオプションは、WHERE句などでNULLとの比較を成立させるかどうかを指定できます。
下のT-SQLでNULL値との比較がTRUEかどうかでANSI_NULLSオプションを取得します。
DECLARE @NULL_VALUE AS bit
SET @NULL_VALUE = NULL
IF NOT EXISTS(
SELECT
'ANSI_NULLS = OFF'
WHERE
@NULL_VALUE = NULL
)
BEGIN
SELECT 'ON' AS [ANSI_NULLS_OPTION]
END
ELSE
BEGIN
SELECT 'OFF' AS [ANSI_NULLS_OPTION]
END ただし、今後のSQL Serverでは、ANSI_NULLSは常にONとなり、
SET ANSI_NULLS OFF を設定するアプリケーションすべてでエラーが発生するようになってしまうそうです。
NULL値との条件指定をする時は必ず" IS NULL "を使うのがベストです。
詳細は下記URLを参照のこと。
SET ANSI_NULLS (Transact-SQL)
http://technet.microsoft.com/ja-jp/library/ms188048.aspx
ちょっと考えればわかるようなことを真顔で書くのが私です。
0 件のコメント:
コメントを投稿