≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 数据库 > SQL Server

Sql Server 索引使用情况及优化的相关Sql语句

人气:481 时间:2019-10-03

这篇文章主要为大家详细介绍了Sql Server 索引使用情况及优化的相关Sql语句,具有一定的参考价值,可以用来参考一下。

感兴趣的小伙伴,下面一起跟随四海网的小编两巴掌来看看吧!

代码如下:

 
--Begin Index(索引) 分析优化的相关 Sql 
-- 返回当前数据库所有碎片率大于25%的索引 
-- 运行本语句会扫描很多数据页面 
-- 避免在系统负载比较高时运行 
-- 避免在系统负载比较高时运行 
declare @dbid int 
select @dbid = db_id() 
SELECT o.name as tablename,s.* FROM sys.dm_db_index_physical_stats (@dbid, NULL, NULL, NULL, NULL) s,sys.objects o 
where avg_fragmentation_in_percent>25 and o.object_id =s.object_id 
order by avg_fragmentation_in_percent desc 
GO 
-- 当前数据库可能缺少的索引 
-- 非常好用的 Sql 语句 
select d.* 
, s.avg_total_user_cost 
, s.avg_user_impact 
, s.last_user_seek 
,s.unique_compiles 
from sys.dm_db_missing_index_group_stats s 
,sys.dm_db_missing_index_groups g 
,sys.dm_db_missing_index_details d 
where s.group_handle = g.index_group_handle 
and d.index_handle = g.index_handle 
order by s.avg_user_impact desc 
go 
-- 自动重建或重新组织索引 
-- 比较好用,慎用,特别是对于在线 DB 
-- Ensure a USE <databasename> statement has been executed first. 
SET NOCOUNT ON; 
DECLARE @objectid int; 
DECLARE @indexid int; 
DECLARE @partitioncount bigint; 
DECLARE @schemaname nvarchar(130); 
DECLARE @objectname nvarchar(130); 
DECLARE @indexname nvarchar(130); 
DECLARE @partitionnum bigint; 
DECLARE @partitions bigint; 
DECLARE @frag float; 
DECLARE @command nvarchar(4000); 
-- Conditionally select tables and indexes from the sys.dm_db_index_physical_stats function 
-- and convert object and index IDs to names. 
SELECT 
object_id AS objectid, 
index_id AS indexid, 
partition_number AS partitionnum, 
avg_fragmentation_in_percent AS frag 
INTO #work_to_do 
FROM sys.dm_db_index_physical_stats (DB_ID(), NULL, NULL , NULL, 'LIMITED') 
WHERE avg_fragmentation_in_percent > 10.0 AND index_id > 0; 
-- Declare the cursor for the list of partitions to be processed. 
DECLARE partitions CURSOR FOR SELECT * FROM #work_to_do; 
-- Open the cursor. 
OPEN partitions; 
-- Loop through the partitions. 
WHILE (1=1) 
BEGIN; 
FETCH NEXT 
FROM partitions 
INTO @objectid, @indexid, @partitionnum, @frag; 
IF @@FETCH_STATUS < 0 BREAK; 
SELECT @objectname = QUOTENAME(o.name), @schemaname = QUOTENAME(s.name) 
FROM sys.objects AS o 
JOIN sys.schemas as s ON s.schema_id = o.schema_id 
WHERE o.object_id = @objectid; 
SELECT @indexname = QUOTENAME(name) 
FROM sys.indexes 
WHERE object_id = @objectid AND index_id = @indexid; 
SELECT @partitioncount = count (*) 
FROM sys.partitions 
WHERE object_id = @objectid AND index_id = @indexid; 
-- 30 is an arbitrary decision point at which to switch between reorganizing and rebuilding. 
IF @frag < 30.0 
SET @command = N'ALTER INDEX ' + @indexname + N' ON ' + @schemaname + N'.' + @objectname + N' REORGANIZE'; 
IF @frag >= 30.0 
SET @command = N'ALTER INDEX ' + @indexname + N' ON ' + @schemaname + N'.' + @objectname + N' REBUILD'; 
IF @partitioncount > 1 
SET @command = @command + N' PARTITION=' + CAST(@partitionnum AS nvarchar(10)); 
EXEC (@command); 
PRINT N'Executed: ' + @command; 
END; 
-- Close and deallocate the cursor. 
CLOSE partitions; 
DEALLOCATE partitions; 
-- Drop the temporary table. 
DROP TABLE #work_to_do; 
GO 

-- 查看当前数据库索引的使用率 
-- 非常的有用 
SELECT 
object_name(object_id) as table_name, 
( 
select name 
from sys.indexes 
where object_id = stats.object_id and index_id = stats.index_id 
) as index_name, 
* 
FROM sys.dm_db_index_usage_stats as stats 
WHERE database_id = DB_ID() 
order by table_name 

-- 指定表的索引使用情况 
declare @table as nvarchar(100) 
set @table = 't_name'; 
SELECT 
( 
select name 
from sys.indexes 
where object_id = stats.object_id and index_id = stats.index_id 
) as index_name, 
* 
FROM sys.dm_db_index_usage_stats as stats 
where object_id = object_id(@table) 
order by user_seeks, user_scans, user_lookups asc 
--End Index 分析优化的相关 Sql 

本文来自:http://www.q1010.com/179/7921-0.html

注:关于Sql Server 索引使用情况及优化的相关Sql语句的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:SQL SERVER

您可能感兴趣的文章

  • SQL Server 一次性压缩Sqlserver2005中所有库日志的存储过程
  • SQLServer 跨库查询实现方法
  • SQL Server 数据库主键的生成方式小结(sqlserver,mysql)
  • SQL Server使用cmd命令行窗口操作SqlServer的方法
  • SQLServer 2005 实现数据库同步备份 过程-结果-分析
  • SQL Server CREATE FUNCTION sqlserver用户定义函数
  • sqlserver 查询数据库大小的方法
  • SQL Server 存储过程解密(破解函数,过程,触发器,视图.仅限于SQLSERVER2000)
  • SQLServer 触发器 数据库进行数据备份
  • SQL Server做购物车系统时利用到得几个sqlserver 存储过程
上一篇:SQL Server 通用的删除服务器上的所有相同后缀的临时表
下一篇:SQL Server 重复数据值只取一条的sql语句
热门文章
  • SQL Server SQL获取第一条记录的方法
  • SQL Server出现System.OutOfMemoryException异常的解决方法
  • SQL Server的 update from 语句的简单示例
  • SQL Server 数据库备份方法菜鸟教程
  • SQL Server 多表关联时在where语句中慎用trim()方法
  • SQL Server数据类型及长度限制详细说明
  • mybaits非配置原因,导致SqlSession was not registered for synchronization异常解析
  • SQL Server 收缩后对数据库的使用有影响吗?
  • SQL Server 格式导致的Excel导入sql出现异常的解决方法
  • SQL Server 连接服务器出现错误 7391的解决方法
  • 最新文章
    • SQL Server存储过程基本语法的简单示例
    • sql查询时增加自动编号和分页的简单示例
    • sql轻松应付百万数据的高效数据分页存储过程的简单示例
    • sql获取一条数据中所有字段的名称和值的实现方法
    • sql分割函数的简单示例
    • SQL Server异常捕获的简单示例
    • SQL SERVER回滚恢复误操作数据的实现方法
    • SQL Server函数或存储过程中抛出异常的实现方法
    • SQL Server创建数据库的完整代码
    • SQL Server创建数据库的命令用法示例

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。