gpt4 book ai didi

sql-server - MSSQL 2012执行 "alter"后查看速度更快

转载 作者:行者123 更新时间:2023-12-03 06:33:53 24 4
gpt4 key购买 nike

我遇到一种情况/上下文,其中特定 View 需要 120 秒才能返回结果。执行简单的 ALTER(或删除/创建)时, View 需要 1 到 2 秒。这怎么可能?我们如何解决这个问题 - 因为我们没有专门的 DBA 可以帮助我们解决这个问题。由于我们拥有链接服务器设置,因此无法创建索引 View (MSSQL Server 2012 对此有所提示)。

以下是有关设置的信息。

TL;DR View_MAIN 在一定时间后需要 120 秒。当我们在 View_X、View_Y 和 View_MAIN 上执行 ALTER View 而不更改任何内容时,性能再次恢复正常,为 1 到 2 秒。

<小时/>

View_MAIN

SELECT 
column1, column2, column3, column4, column5
FROM View_X

UNION ALL

SELECT
column1, column2, column3, column4, column5
FROM View_Y

View_X

SELECT
LTRIM(RTRIM(table1.a)) as column1,
table2.b COLLATE Latin1_General_CI_AS as column2,
table1.c as column3,
CAST(table3.d AS DATETIME) as column4,
'XXXXXX' as column5
FROM
[linkedserver01].[DATABASE_IDN].[dbo].[dataForX] table1
LEFT OUTER JOIN [linkedserver02].[DATABASE_INFM] as table2
ON table2.id = table1.id
LEFT OUTER JOIN [linkedserver02].[DATABASE_PIK] as table3
ON table3.id = table1.id

View_Y

SELECT
LTRIM(RTRIM(table1.a)) as column1,
table2.b COLLATE Latin1_General_CI_AS as column2,
table1.c as column3,
CAST(table3.d AS DATETIME) as column4,
'YYYYY' as column5
FROM
[linkedserver01].[DATABASE_IDN].[dbo].[dataForY] table1
LEFT OUTER JOIN [linkedserver02].[DATABASE_INFM] as table2
ON table2.id = table1.id
LEFT OUTER JOIN [linkedserver02].[DATABASE_PIK] as table3
ON table3.id = table1.id

最佳答案

通过更改或重新创建 View ,您将清除为此而存在的缓存执行计划,并根据当前数据集重新创建它。

执行sp_recompile 'View_Main'也可以达到同样的效果

https://technet.microsoft.com/en-us/library/ms181055(v=sql.105).aspx

查看查询的实际执行计划应该是确定查询运行缓慢的原因的起点(在 SSMS 中的“查询”菜单上)

关于sql-server - MSSQL 2012执行 "alter"后查看速度更快,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37138675/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com