MSSQL 2005 查看/处理 库中所有表的索引碎片
2010-04-28 12:55
225 查看
MSSQL 2005 提供了一个动态管理函数 sys.dm_db_index_physical_stats,可以方便直观地查看到指定表或视图的数据和索引的大小和碎片信息。
下面这条语句,可以查看当前数据库中所有索引的碎片情况:
SELECT
object_name(a.object_id) [TableName]
,a.index_id
,name [IndexName]
,avg_fragmentation_in_percent
FROM sys.dm_db_index_physical_stats
(
DB_ID()
, NULL , NULL, NULL, NULL
) AS a
JOIN sys.indexes AS b
ON a.object_id = b.object_id AND a.index_id = b.index_id;
下面这条语句重建索引:
ALTER INDEX ALL ON [dbo].[YourTableName]
REBUILD WITH (
SORT_IN_TEMPDB = ON
,STATISTICS_NORECOMPUTE = ON
,ONLINE = ON);
另外还可以通过向导方式整理索引(推荐):
表→索引→属性→选项→重新生成索引(勾选)→确定
下面这条语句,可以查看当前数据库中所有索引的碎片情况:
SELECT
object_name(a.object_id) [TableName]
,a.index_id
,name [IndexName]
,avg_fragmentation_in_percent
FROM sys.dm_db_index_physical_stats
(
DB_ID()
, NULL , NULL, NULL, NULL
) AS a
JOIN sys.indexes AS b
ON a.object_id = b.object_id AND a.index_id = b.index_id;
下面这条语句重建索引:
ALTER INDEX ALL ON [dbo].[YourTableName]
REBUILD WITH (
SORT_IN_TEMPDB = ON
,STATISTICS_NORECOMPUTE = ON
,ONLINE = ON);
另外还可以通过向导方式整理索引(推荐):
表→索引→属性→选项→重新生成索引(勾选)→确定
相关文章推荐
- Sqlserver:在sql2005查看索引的碎片统计情况,并给出处理意见的自动化批处理脚本
- SQL Server 重建索引|索引重组|索引的碎片检查 (MSSQL个人笔记之数据库优化之路 六<SQL2005以上>)
- Sqlserver 2005+:查看索引【index】的【碎片】
- MSSQL2005 查找索引,和删除表的所有索引
- 删除指定表的所有索引,包括主键索引,唯一索引和普通索引 ,适用于sql server 2005,
- 分析balde源码,查看Web工程处理Ioc注入的背后的过程,ThreadLocal 使用保存线程所有的request and respond,
- SQLServer中的索引碎片处理
- [置顶]一个查看MSSQL数据库中所有表信息的SQL语句
- 删除指定表的所有索引,包括主键索引,唯一索引和普通索引 ,适用于sql server 2005,
- SQL Server 2005索引碎片整理SQL语句
- sql server 查询所有表的字段的详细信息的存储过程(在 SQL Server 2005 中查询表结构及索引 )
- sql server 2005清除索引碎片
- 一个查看MSSQL数据库中所有表信息的SQL语句
- 检查SQL Server 2005的索引密度和碎片信息(转)
- SQL SERVER 2005 获取表的所有索引信息以及删除和新建语句
- SqlServer2005 性能调校之利用sys.dm_db_index_physical_stats查看索引大小/碎片
- 利用sys.dm_db_index_physical_stats查看索引碎片等数据
- SQL Server 2005:索引碎片整理脚本(网摘)
- SQL Server 2005索引碎片整理