sql - T-SQL 查询运行非常缓慢
问题描述
我有一个查询,我认为它异常长,所以我正在改变事物并尝试不同的事物来加快它。目前,返回少于 11k 条记录需要 3 到 4 分钟。
这是我的查询:
DECLARE @PtVistitOID TABLE (
PatientVisitOID INT NOT NULL
)
INSERT INTO @PtVistitOID
SELECT DISTINCT PatientVisitOID
FROM smsdss.c_covid_ptvisitoid_tbl
WHERE PatientVisitOID IS NOT NULL
SELECT
A.OBJECTID AS PatientVisit_OID,
A.PATIENTACCOUNTID,
A.PatientVisitExtension_OID
FROM
[SC_server].[Soarian_Clin_Prd_1].DBO.HPatientVisit AS A
INNER JOIN
[SC_server].[Soarian_Clin_Prd_1].dbo.HExtendedPatientVisit AS B ON A.PatientVisitExtension_OID = B.objectid
INNER JOIN
@PtVistitOID AS C ON A.ObjectID = C.PatientVisitOID
--WHERE A.ObjectID IN (SELECT PatientVisitOID FROM @PtVistitOID);
当我检查估计的查询执行计划时,它说大约 95% 的时间都花在向表中插入记录上@PtVisitOID
,这部分查询将尽可能快地运行,你可以单击执行,在 13,970 行中@PtVisitOID
。所以剩下的 5% 来自查询的其余部分。整个查询又需要 3 到 4 分钟。
所有的连接都在完全相同类型的列上,INT。
我可以相当快地从所有单独的表中选择记录,不到 5 秒。特别是当我添加最后一个INNER JOIN
或将其更改为 aWHERE A.ObjectID IN (SELECT PatientVisitOID FROM @PtVisitOID)
时,查询时间就会增加。
有什么想法吗?
解决方案
我已经重组了我编写查询的方式,并且很高兴地注意到执行时间下降到 1 到 2 秒之间。我确实撤回了更少的记录,但这很好,因为其他不再回来的记录毫无用处。这本身并不是加速的原因,重组才是。
DECLARE @PtVistitOID TABLE (
PatientVisitOID INT NOT NULL
)
INSERT INTO @PtVistitOID
SELECT DISTINCT PatientVisitOID
FROM smsdss.c_covid_ptvisitoid_tbl
WHERE PatientVisitOID IS NOT NULL
DECLARE @UserDefinedString TABLE (
PatientVisit_OID INT,
PatientAccountID INT,
Covid_Indicator VARCHAR(1000)
)
INSERT INTO @UserDefinedString
SELECT A.OBJECTID AS PatientVisit_OID,
A.PATIENTACCOUNTID,
--A.PatientVisitExtension_OID,
B.UserDefinedString20
FROM [SC_server].[Soarian_Clin_Prd_1].DBO.HPatientVisit AS A
INNER JOIN [SC_server].[Soarian_Clin_Prd_1].dbo.HExtendedPatientVisit AS B ON A.PatientVisitExtension_OID = B.objectid
WHERE A.PatientVisitExtension_OID IS NOT NULL
AND B.UserDefinedString20 IS NOT NULL
AND B.UserDefinedString20 != ''
SELECT A.PatientVisitOID,
B.PatientAccountID,
B.Covid_Indicator
FROM @PtVistitOID AS A
INNER JOIN @UserDefinedString AS B
ON A.PatientVisitOID = B.PatientVisit_OID
通过不混合本地和链接服务器表的建议,通过选择在本地@tables 内生成所有结果,实现了所需的加速。
推荐阅读
- java - spring boot 不包括 .jar 文件上的 RestController
- java - ClassUtils.getDefaultClassLoader().getResource("").getPath() 得到的结果值包含'!'
- verilog - Verilog / SystemC中的Dataflow模型和RTL样式编码有什么区别
- css - Bootstrap全屏模式右侧错误
- pandas - `replace` 对数据框不起作用
- c - 如何在 GRPC++ 中获取客户端证书或更准确地说是客户端 DN?
- r - 为什么我的复选框按钮在闪亮的应用程序中没有响应?
- javascript - 遇到多个 Dragabblevanilla javascript 模态框的问题
- c++ - IMFSinkWriter :请求无效,因为已调用 Shutdown()
- r - R beakr 脚本作为 Rscript Windows 10 服务