我正在向我的 netcore 网站添加一些健康检查。其中之一是检查连接字符串是否指向已激活内存表支持的数据库(主要是如果文件组是使用 CONTAINS MEMORY_OPTIMIZED_DATA 标志创建的)。
运行状况检查将使用此查询:
IF((SELECT COUNT(1) FROM sys.filegroups FG
JOIN sys.database_files DF
ON FG.data_space_id = DF.data_space_id
JOIN sys.master_files MF
ON DF.file_id = MF.file_id
JOIN sys.databases DB
ON DB.database_id = MF.database_id
where FG.type = 'FX'
and DB.name ='MyDB')>0)
BEGIN
SELECT 1
END
ELSE
BEGIN
RAISERROR ('Memory file group not set',
18, -- Severity,
-1); -- State);
END
并通过以下方式注册:
.AddSqlServer(connectionString: connString,
healthQuery: myHealthQuery, name: HealthCheckNames.InMemoryState)
查询确实返回 1,没有任何错误。我已经设置了一个分析器来运行它,并且没有抛出任何错误(我可以看到 Select 1 正在返回)。
尽管如此,该健康检查返回不健康。
知道为什么吗?