为什么必须使用quoted_identifier才能使用过滤索引?

gza*_*zak 7 sql-server quoted-identifier filtered-index

这里有很多关于如何处理这个混乱的SO和文章的问题,但我的问题更为基础:为什么?带引号的标识符似乎是引擎如何解释查询的属性,而与内部数据无关.就索引和插入/更新查询而言,谁在乎呢?为什么这个设置很重要?

假设您允许插入/更新成功,并且在带有筛选索引的表中将quoted_identifier设置为OFF - 究竟会破坏什么?

Dav*_*oft 3

错误消息包含一条线索:

"Verify that SET options are correct for use with 
indexed views and/or 
indexes on computed columns and/or 
filtered indexes and/or 
query notifications and/or
XML data type methods and/or 
spatial index operations."
Run Code Online (Sandbox Code Playgroud)

所有这些功能都需要一组规范的 SET 选项。对于插入带有过滤索引的表,QUOTED_IDENTIFIERS 可能有效,因为正如您所说,它只影响查询文本的解析。但这些其他功能之一在 QUOTED_IDENTIFIERS 关闭的情况下无法使用。

QUOTED_IDENTIFERS 在查询解析中是如此奇怪(并且不建议将其关闭),这可能与事实一样平凡,以至于在这些场景中支持它根本不值得付出努力。

*请参阅https://learn.microsoft.com/en-us/sql/t-sql/statements/set-quoted-identifier-transact-sql,其中解释了会话设置的差异及其在顶级广告中的行为-hoc 批处理、存储过程和嵌套批处理。