7

我注意到某个数据库中存在假设索引。我四处搜索,似乎这种类型的索引是由Tuning Advisor创建的,并不总是被删除。

有几个主题,包括有关如何清除/删除这些索引的官方文档,但我无法找到这些索引是否对服务器本身有任何影响。

我使用下面的脚本检查的是没有关于它们的大小信息:

SELECT OBJECT_NAME(I.[object_id]) AS TableName
      ,I.[name] AS IndexName
      ,I.[index_id] AS IndexID
      ,8 * SUM(A.[used_pages]) AS 'Indexsize(KB)'
FROM [sys].[indexes] AS I
INNER JOIN [sys].[partitions] AS P 
    ON P.[object_id] = I.[object_id] 
    AND P.[index_id] = I.[index_id]
INNER JOIN [sys].[allocation_units] AS A 
    ON A.[container_id] = P.[partition_id]
WHERE I.[is_hypothetical] = 1
GROUP BY I.[object_id]
        ,I.[index_id]
        ,I.[name]
ORDER BY 8 * SUM(A.[used_pages]) DESC

有了它们,我决定检查是否有一些关于它们的使用信息,以便留下经常使用的这些,但再次没有返回。(我使用了本文中的“现有索引使用统计信息” )。

谁能告诉为什么保留这些索引是错误的,如果我可以定义应该保留哪些索引?

4

3 回答 3

5

只是USE您要清理和运行的数据库:

DECLARE @sql VARCHAR(MAX) = ''

SELECT
    @sql = @sql + 'DROP INDEX [' + i.name + '] ON [dbo].[' + t.name + ']' + CHAR(13) + CHAR(10)
FROM 
    sys.indexes i 
    INNER JOIN sys.tables t 
        ON i.object_id = t.object_id 
WHERE 
    i.is_hypothetical = 1


EXECUTE sp_sqlexec @sql
于 2015-08-26T20:14:29.800 回答
3

只需删除它们,它们实际上并不会占用任何空间或根本不会造成任何性能损失/收益,但是如果您正在查看在表上定义了哪些索引而忘记排除假设索引,则可能会引起一些混乱,同样,如果您尝试创建与这些索引之一同名的索引,它也会失败,因为它已经存在。

于 2014-01-14T14:06:38.283 回答
0

如果您使用自定义模式并检查分析索引视图,则需要对上述脚本进行一些进一步的改进:

DECLARE     @sql VARCHAR(MAX) = ''

SELECT      @sql = @sql 
            + 'DROP INDEX [' + i.name + ']'
            + 'ON [' + OBJECT_SCHEMA_NAME(t.[object_id]) + '].[' + t.name + ']' 
            + CHAR(13) + CHAR(10)
FROM        sys.indexes i 
INNER JOIN  sys.[all_objects] t 
ON          i.object_id = t.object_id 
WHERE       i.is_hypothetical = 1

PRINT       @sql

EXECUTE     sp_sqlexec @sql
于 2020-04-28T11:37:11.910 回答