繁体   English   中英

azure 托管实例 sql server 数据库上的基本查询非常慢

[英]basic query very slow on azure managed instance sql server database

在 Azure 托管的 sql server 实例数据库上,我做

Select top 1000 * from _CSP_Detail.

数据表是空的,因为我昨天从表中删除了所有数据(Delete * from _CSP_Detail)。
它曾经有一百万行,删除需要一段时间。 表上定义了满满一手的索引/索引。

删除后,今天,我发现

Select top 1000 * from _CSP_Detail

正如预期的那样,什么都不拉,但需要一分钟多的时间才能运行。

困惑。 有任何想法吗?

看来你的表是一个堆(没有聚集索引)。 从堆中删除行时不会回收空间,因此即使表为空,也必须通过SELECT查询扫描分配的页面以查找行。

显式TRUNCATE表或创建/删除聚集索引以回收空间并提高针对空表的性能。

请注意,根据文档,表通常应具有聚集索引。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM