• (4.8)SET ANSI_NULLS ON、SET QUOTED_IDENTIFIER ON


    T-SQL支持在与空值进行比较时,允许比较运算符返回 TRUE 或 FALSE。

    通过设置 ANSI_NULLS OFF 可将此选项激活。
    当 ANSI_NULLS 为 OFF 时,如果 ColumnA 包含 Null 值,则 ColumnA = NULL 之类的比较操作会返回 TRUE;如果 ColumnA 除了包含 NULL 外还包含某些值,则这类比较操作将返回 FALSE。比较计算结果为 NULL 的两个表达式也会返回 TRUE。

    ANSI_NULLS 设置不影响包含 NULL 的联接列。联接列中包含 NULL 的行不是结果集的一部分。

    当 ANSI_NULLS 设置为 OFF 时,以下 SELECT 语句返回 Customer 表中 Region 为 Null 值的所有行:

    复制代码
      SELECT CustomerID, AccountNumber, TerritoryID
      FROM AdventureWorks.Sales.Customer
      WHERE TerritoryID = NULL

    如果 SET ANSI_NULLS ON
    那么 SQL 语句中, 判断 非空的写法, 要修改为:
    WHERE 字段 IS NULL

    因为 SET ANSI_NULLS ON 以后,
    NULL = NULL 将 返回 false.

    这些是 SQL-92 设置语句,使 SQL Server 2000/2005 遵从 SQL-92 规则。

    SQL-92 标准要求在对空值进行等于 (=) 或不等于 (<>) 比较时取值为 FALSE。当 SET ANSI_NULLS 为 ON 时,即使 column_name 中包含空值,使用 WHERE column_name = NULL 的 SELECT 语句仍返回零行。即使 column_name 中包含非空值,使用 WHERE column_name <> NULL 的 SELECT 语句仍会返回零行。
    当 SET ANSI_NULLS 为 OFF 时,等于 (=) 和不等于 (<>) 比较运算符不遵从 SQL-92 标准。使用 WHERE column_name = NULL 的 SELECT 语句返回 column_name 中包含空值的行。使用 WHERE column_name <> NULL 的 SELECT 语句返回列中包含非空值的行。此外,使用 WHERE column_name <> XYZ_value 的 SELECT 语句返回所有不为 XYZ_value 也不为 NULL 的行。

    当 SET QUOTED_IDENTIFIER 为 ON 时,标识符可以由双引号分隔,而文字必须由单引号分隔。当 SET QUOTED_IDENTIFIER 为 OFF 时,标识符不可加引号,且必须符合所有 Transact-SQL 标识符规则。

    SET QUOTED_IDENTIFIER ON 

    在存储过程中经常会有 

    Sql代码  收藏代码
    1. SET QUOTED_IDENTIFIER on  
    2. SET QUOTED_IDENTIFIER off  



    这样的语句,那么SET QUOTED_IDENTIFIER到底是什么意思,有什么用呢,今天下午仔细的看了一下。 

    如果SET QUOTED_IDENTIFIER on时,在创建一个表时,如果这个表的表名,刚好用到了sqlserver的标识符,如下面的情况 


    Sql代码  收藏代码
    1. create table distinct(  
    2.  id int not  null constraint pk_1 primary   key,  
    3.  value varchar(255),  
    4.  flag int  
    5. )  


    上面的语句运行是会出错的,不管SET QUOTED_IDENTIFIER为on还是off,会提示  在关键字 'distinct' 附近有语法错误。 

    那是因为distinct是sqlserver的标识符,如果想以distinct为表时,在QUOTED_IDENTIFIER为off的情况下,是不能创建表名为distinct的表的,因为在QUOTED_IDENTIFIER为off情况下,sqlserver的标识符是不允许加引号的,所以在 
    SET QUOTED_IDENTIFIER  off的情况下,不管distinct加引号或不加引号或加双引号都是不可以的。 

    但是在 SET QUOTED_IDENTIFIER on 的情况下是可以把sqlserver的标识符加上双引号来创建以sqlserver标识符为表名的表,但是加单引号也是不可以的。 

    Sql代码  收藏代码
    1. create table "distinct"(  
    2.  id int not  null constraint pk_1 primary   key,  
    3.  value varchar(255),  
    4.  flag int  
    5. )  


    可以运行 

    Sql代码  收藏代码
    1. create table ‘distinct’(  
    2.  id int not  null constraint pk_1 primary   key,  
    3.  value varchar(255),  
    4.  flag int  
    5. )  


    不可以运行 

  • 相关阅读:
    nginx中目录转义字符问题
    2022年3月2日最近的状态~
    [esp8266]官方SDK与arduino ROM或Flash布局,Vscode+platformio 如何设置
    什么是并发容器
    Executor, ExecutorService 和 Executors区别与联系
    Spirng和SpringBoot中的Aop优先使用的是JDK动态代理还是Cglib
    建造者模式
    MySQL四大排名函数
    SpringMVC执行流程解析(PS:使用了适配器模式)
    适配器模式
  • 原文地址:https://www.cnblogs.com/gered/p/9388521.html
Copyright © 2020-2023  润新知