0

我创建了一个过滤的非聚集索引以优化特定的查询集,但我开始从各种来源得到以下错误:

UPDATE 失败,因为以下 SET 选项的设置不正确:“ANSI_NULLS”。验证 SET 选项对于索引视图和/或计算列上的索引和/或过滤索引和/或查询通知和/或 XML 数据类型方法和/或空间索引操作是否正确。

似乎某些遗留例程是使用该SET ANSI_NULLS OFF选项创建的,并且当引擎尝试从给定上下文更新目标表时,会引发错误。

我想知道有没有办法查看使用此选项创建的例程。例如,如果您编写这样的例程脚本,您会得到如下内容:

SET ANSI_NULLS OFF
GO

SET QUOTED_IDENTIFIER ON
GO

CREATE PROCEDURE ....

我通常使用如下脚本在对象定义中查找内容,但此设置不是其中的一部分:

DECLARE @SearchWord NVARCHAR(128) = 'SET ANSI_NULLS OFF' 
SELECT [ROUTINE_NAME] 
FROM [INFORMATION_SCHEMA].[ROUTINES]
WHERE [ROUTINE_DEFINITION] LIKE '%' + @SearchWord+'%' 
UNION
SELECT OBJECT_NAME([id]) 
FROM [SYSCOMMENTS]
WHERE [text] LIKE '%' + @SearchWord + '%' 
GROUP BY OBJECT_NAME([id])
UNION 
SELECT OBJECT_NAME(object_id)
FROM [sys].[sql_modules]
WHERE [definition] LIKE '%' + @SearchWord + '%' ;
4

2 回答 2

3

一个简单的搜索可以做到这一点,例如这样

SELECT DISTINCT
       o.name AS Object_Name,
       o.type_desc,
       m.*
FROM   sys.sql_modules m
  INNER JOIN sys.objects o ON m.object_id = o.object_id
WHERE  m.uses_ansi_nulls = 0
于 2019-05-27T13:45:20.303 回答
2

您可以只安装 Redgate 的 SQL Search 或其他供应商的类似产品。然后很容易搜索这样的东西。

对于一次性,类似

SELECT * FROM sys.sql_modules WHERE definition LIKE '% ansi %'

应该这样做。或者

SELECT * FROM sys.sql_modules WHERE definition uses_ansi_nulls = 1

请参阅sys.sql_modules (Transact-SQL)

于 2019-05-27T13:31:40.763 回答