SQL Server中SET QUOTED_IDENTIFIER的使用

SQL Server中SET QUOTED_IDENTIFIER的使用

大家好,又见面了,我是全栈君。

SQL Server中SET QUOTED_IDENTIFIER的使用

 

 

在存储过程中经常会有
SET QUOTED_IDENTIFIER on
SET QUOTED_IDENTIFIER off

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

create table distinct(
id int not null constraint pk_1 primary key,
value varchar(255),
flag int
)

上面的语句运行是会出错的,不管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标识符为表名的表,但是加单引号也是不可以的。

create table “distinct”(
id int not null constraint pk_1 primary key,
value varchar(255),
flag int
)

可以运行

create table ‘distinct’(
id int not null constraint pk_1 primary key,
value varchar(255),
flag int
)

不可以运行

 

当 SET QUOTED_IDENTIFIER 为 ON 时,标识符/数据库内关键字可以由双引号括着。当 SET QUOTED_IDENTIFIER 为 OFF 时,标识符不可加引号,加了引号也没有用,且必须符合所有 Transact-SQL 标识符规则。

 

SELECT SESSIONPROPERTY(‘QUOTED_IDENTIFIER’) quotedidentifier
默认为on

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/108273.html原文链接:https://javaforall.net

(0)
上一篇 2022年3月5日 下午8:00
下一篇 2022年3月5日 下午8:00


相关推荐

  • 军师旅团营连排班各有多少人

    军师旅团营连排班各有多少人一个 bai 军有 50000 到 70000 人 一个 du 师有 12000 到 zhi15000 人 一个旅有 6000 到 8000 人 一个团有 1200 到 1500 人 一个营有 500 到 700 人 一个连有 dao105 到 120 人 一个排有 36 人 一个班有 12 人 一个小队有 50 到 70 人 一个中队有 500 人 一个大队有 1200 人

    2026年3月26日
    3
  • 非常实用 Claude Code 必知设置技巧

    非常实用 Claude Code 必知设置技巧

    2026年3月15日
    3
  • java volatile关键字的作用_java volatile关键字作用及使用场景详解

    java volatile关键字的作用_java volatile关键字作用及使用场景详解1.volatile关键字的作用:保证了变量的可见性(visibility)。被volatile关键字修饰的变量,如果值发生了变更,其他线程立马可见,避免出现脏读的现象。如以下代码片段,isShutDown被置为true后,doWork方法仍有执行。如用volatile修饰isShutDown变量,可避免此问题。publicclassVolatileTest3{staticclassW…

    2022年5月31日
    37
  • 关于cv::imread读取图片类型的初探[通俗易懂]

    关于cv::imread读取图片类型的初探[通俗易懂]关于cv::imread读取图片类型的初探问题来源环境首先生成单通道和三通道的png图片cv::imread函数及其参数不同参数读取rgb图像不同参数读取单通道图片问题来源在处理深度图的时候,在用cv::imread读取深度图像时,本以为得到的是单通道图,但实际是三通道图。所以仔细看了一下cv::imread函数。环境Ubuntu16Opencv4.0.0首先生成单通道和三通…

    2022年10月14日
    6
  • 3D打印上位机软件

    3D打印上位机软件本文将主要介绍在3D打印中常见的3D打印上位机软件,这类3D软件将为用户提供较大的帮助,通过对这类软件的分类,用户可以选择使用最适合自己的软件。没有恐惧,我们已经回答了所有这些问题,以及熟练程度的细节和可以下载的细节。最重要的是,他们大多数是完全免费和开源的。我们错过了您最喜爱的3D打印软件吗?让我们在评论中知道,我们会在将来的更新中添加它们。1、curaCura可以被称…

    2022年5月31日
    70
  • Spark: sortBy和sortByKey函数详解

    Spark: sortBy和sortByKey函数详解在很多应用场景都需要对结果数据进行排序 Spark 中有时也不例外 在 Spark 中存在两种对 RDD 进行排序的函数 分别是 sortBy 和 sortByKey 函数 sortBy 是对标准的 RDD 进行排序 它是从 Spark nbsp 0 9 0 之后才引入的 可以参见 SPARK 1063 而 sortByKey 函数是对 PairRDD 进行排序 也就是有 Key 和 Value 的 RDD 下面将分别对这两个函数的实现以及使用进

    2026年3月17日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号