2

文档指出,数据库 ANSI_NULLS 标志控制在某些方面与 null 进行比较的行为。

我正在检查此堆栈溢出帖子以检查如何确定(未设置)此标志的值。有趣的是,并非所有答案似乎都对我有用。

我的测试查询:

create table x(id int,txt nvarchar(max))
insert x(id,txt) values (1,'not null here'),(2,null)
select * from x

--query 1
select * from x where txt=null

--query 2
select * from x where txt<>null

返回的输出是两个空结果集。由此,我可以从逻辑上推断出数据库中的 ANSI_NULLS 为 ON。

现在,检查选项:

1

select databasepropertyex('MyDatabaseName', 'IsAnsiNullsEnabled')

返回 0。我没想到会这样。

2

DECLARE @options INT
SELECT @options = @@OPTIONS
IF ( (32 & @options) = 32 ) PRINT 'ANSI_NULLS'

打印“ANSI_NULLS”。预期的。

3

SELECT is_ansi_nulls_on FROM sys.databases WHERE name = 'MyDatabaseName'

返回 0。我没想到会这样。

4

dbcc useroptions

结果集包括 [Set Option]='ansi_nulls' 和 [Value]='Set' 的行。预期的。


为什么选项 1 和 3 会给我这个结果?

我的@@version 是:

Microsoft SQL Server 2017 (RTM-GDR) (KB4505224) - 14.0.2027.2 (X64) 
    Jun 15 2019 00:26:19 
    Copyright (C) 2017 Microsoft Corporation
    Developer Edition (64-bit) on Windows Server 2019 Standard 10.0 <X64> (Build 17763: ) (Hypervisor)
4

2 回答 2

2

您的查询正在查看两个不同的内容。

一个是数据库默认值(可以用 更改ALTER DATABASE SET)-另一个是在当前会话中设置的值。

数据库默认值实际上是无用的,因为连接到 SQL Server 的所有常用ANSI_NULLS方法都设置为如下所述

使用 SET 语句设置的连接级别设置会覆盖 ANSI_NULLS 的默认数据库设置。默认情况下,ODBC 和 OLE DB 客户端发出连接级 SET 语句,将会话的 ANSI_NULLS 设置为 ON。当您连接到 SQL Server 实例时,客户端会运行该语句。有关详细信息,请参阅 SET ANSI_NULLS。

于 2020-05-08T15:07:42.703 回答
0

会议:

set ansi_nulls on;

select sessionproperty('ANSI_NULLS');

select ansi_nulls
from sys.dm_exec_sessions
where session_id = @@spid;

select case when null=null then 0 else 1 end;
-------------
set ansi_nulls off;

select sessionproperty('ANSI_NULLS');

select ansi_nulls
from sys.dm_exec_sessions
where session_id = @@spid;

select case when null=null then 0 else 1 end;
于 2020-05-08T17:25:27.683 回答