当前位置: 首页 > news >正文

SQL存储过程中 SET ANSI_NULLS ON 和 SET QUOTED_IDENTIFIER ON的作用和详解

今天在写SQL Server存储过程中遇到的,做个整理归纳

USE [ABInbevDB]
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO

实际上,我们在创建存储过程的时候,这几行的代码是会自动创建出来的,那么先解释下两个标准的概念。

两个标准

当我们在编写存储过程时,存在两种标准可供选择:ANSI_NULLS 和 QUOTED_IDENTIFIER。下面我会对这两个标准进行详细说明:

  1. ANSI_NULLS(ANSI 空值处理规则):

    • SET ANSI_NULLS ON:启用 ANSI 空值处理规则。在比较和操作 NULL 值时,使用 ANSI 标准。它要求任何包含 NULL 值的比较都返回未知(UNKNOWN)结果。
    • 比较 NULL 值:当使用 = 或 <> 等比较运算符与 NULL 值进行比较时,结果将返回未知(UNKNOWN),而不是 TRUE 或 FALSE。这是 ANSI 标准的要求。
    • 操作 NULL 值:在执行某些操作时,如连接、聚合函数等,涉及到 NULL 值的行为也符合 ANSI 标准。例如,在连接操作中,如果有一个或多个 NULL 值,连接将不返回任何匹配。
  2. QUOTED_IDENTIFIER(引号标识符):

    • SET QUOTED_IDENTIFIER ON:启用引号标识符。在引用对象名称时,使用双引号作为标识符的限定符。
    • 引号标识符:引号标识符是用于引用包含特殊字符或保留字的对象名称的方法。在 SQL Server 中,通常使用双引号 (“”) 将标识符括起来。
    • 特殊字符和保留字:有些对象名称可能包含特殊字符,如空格或减号。在这种情况下,使用引号标识符是必须的,以区分标识符与字符本身的含义。此外,某些词可能是 SQL 的保留字,如果要使用它们作为对象名称,也需要使用引号标识符。

作用

这两个设置的默认状态在大多数情况下都是启用的(即 ON)。因此,在大多数情况下,不需要在存储过程中显式设置这些选项,除非你的数据库或服务器级别设置已更改。按照最佳实践,建议始终使用这两个设置,以确保代码在不同环境中的一致性和可移植性

http://www.lryc.cn/news/146226.html

相关文章:

  • C语言——程序执行的三大流程
  • 二级MySQL(十)——单表查询
  • 机器学习:无监督学习
  • 计算机网络之5层网络协议
  • 常见前端面试之VUE面试题汇总十一
  • 2021年12月 C/C++(五级)真题解析#中国电子学会#全国青少年软件编程等级考试
  • 解决 git clone 时出现Failed to connect to 127.0.0.1 port 1573问题
  • 日本核污染水排海,有必要囤盐吗?
  • windows 10自带命令查看文件的哈希值
  • ssm+vue理发店会员管理系统源码和论文
  • Python的for循环
  • 爬虫逆向实战(二十七)--某某招标投标网站招标公告
  • 线程和之间的通讯方式、进程之间的通讯方式、线程之间如何同步
  • CRM线索公海如何管理?
  • 创建web应用程序,React和Vue怎么选?
  • 【每日一题】1267. 统计参与通信的服务器
  • Python入门教程29:字符串前加r、u、b、f是什么意思?
  • java8 IntStream.range
  • 数据库集群的简单了解
  • CSS中如何实现文字阴影效果(text-shadow)?
  • Nginx从入门到精通(超级详细)
  • 为何反射探针关闭Mipmap后变成了白图
  • 成都睿趣科技:抖音开网店前期的流程是什么
  • 机房安全之道:构筑坚固的网络防线
  • 使用GoLand进行远程调试
  • C++通过JNI调用JAVA方法返回ArrayList对象
  • .netcore grpc截止时间和取消详解
  • React组件间数据传递(弹框和高阶组件(HOC)特性实现)
  • 只考一门数据结构,计算机学硕复录比1:1的山东双非学校考情分析
  • SpringMVC之异常处理器