微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

DBCC大全集之适用版本MS SQLServer 2008 R2----DBCC UPDATEUSAGE报告目录视图中的页数和行数错误并进行更正

报告目录视图中的页数和行数错误并进行更正。这些错误可能导致 sp_spaceused 系统存储过程返回不正确的空间使用报告。

主题链接图标

 Transact-SQL 语法约定

DBCC UPDATEUSAGE 
(   { database_name | database_id | 0 } 
    [,{ table_name | table_id | view_name | view_id } 
    [,{ index_name | index_id } ] ] 
) [ WITH [ NO_INFOMSGS ] [,] [ COUNT_ROWS ] ] 
参数

database_name |  database_id | 0

要对其空间使用统计信息进行报告和更正的数据库名称或 ID。如果指定 0,则使用当前数据库数据库名称必须符合有关标识符的规则。

table_name |  table_id |  view_name |  view_id

要对其空间使用统计信息进行报告和更正的表或索引视图的名称或 ID。表和视图的名称必须符合标识符规则。

index_id |  index_name

要使用的索引的 ID 或名称。如果未指定,语句将对指定的表或视图的所有索引进行处理。

WITH

允许指定选项。

NO_INFOMSGS

取消显示所有信息性消息。

COUNT_ROWS

指定使用表或视图中的行数的当前计数更新 row count 列。

注释

DBCC UPDATEUSAGE 将针对表或索引中的每个分区更正行、已用页、保留页、叶级页和数据页的计数。如果系统表中没有错误,则 DBCC UPDATEUSAGE 不返回数据。如果发现错误,并对其进行了更正,同时没有使用 WITH NO_INFOMSGS,DBCC UPDATEUSAGE 将返回系统表中更新的行和列。

DBCC CHECKDB 已得到增强,可以检测页计数或行计数变为负值的情况。检测到上述问题后,DBCC CHECKDB 的输出会包含一个警告和一个建议,建议运行 DBCC UPDATEUSAGE 解决该问题。

最佳做法

  • sql Server 2000 升级数据库后始终运行 DBCC UPDATEUSAGE。这将更正页计数和行计数并在以后加以保持。

  • 对于在 sql Server 2005 或更高版本中创建的数据库,或曾经使用 DBCC UPDATEUSAGE 更正的已升级数据库,请勿定期运行 DBCC UPDATEUSAGE。由于对大型表或数据库运行 DBCC UPDATEUSAGE 会耗费一定的时间,因此不应使用此语句,除非您怀疑 sp_spaceused 返回了不正确的值。

  • 只有数据库的 CREATE、ALTER 或 DROP 语句等数据定义语言 (DDL) 经常受到修改时,才应考虑定期运行 DBCC UPDATEUSAGE(例如,每周运行一次)。

结果集

权限

要求拥有 sysadmin 固定服务器角色或 db_owner 固定数据库角色的成员身份。

示例

A. 为当前数据库中的所有对象更新页计数或行计数,或同时更新这两者

下面的示例将数据库名称指定为 0,且 DBCC UPDATEUSAGE 报告当前数据库的已更新页计数或行计数信息。

DBCC UPDATEUSAGE (0);
GO


B. 更新页计数或行计数,或同时更新这两者,并禁止显示信息性消息。

下面的示例将 AdventureWorks2008R2 指定为数据库名称,并禁止显示所有信息性消息。

USE AdventureWorks2008R2;
GO
DBCC UPDATEUSAGE (AdventureWorks2008R2) WITH NO_INFOMSGS; 
GO


C. 为某一表更新页计数或行计数,或同时更新这两者

下面的示例报告 AdventureWorks2008R2 数据库中 Employee 表的已更新页计数或行计数信息。

USE AdventureWorks2008R2;
GO
DBCC UPDATEUSAGE (AdventureWorks2008R2,"HumanResources.Employee");
GO


D. 为表中的特定索引更新页计数或行计数,或同时更新这两者

下面的示例指定一个索引名称

ottom:0px; overflow:auto; word-wrap:normal; font-family:Consolas,"HumanResources.Employee",IX_Employee_OrganizationLevel_OrganizationNode);
GO

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐