亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

Sql Server 索引使用情況及優化的相關Sql語句分享

2024-08-31 00:57:19
字體:
來源:轉載
供稿:網友

復制代碼 代碼如下:


--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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美成人亚洲成人| 97热在线精品视频在线观看| 少妇高潮久久久久久潘金莲| 亚洲国产天堂久久综合| 国产一区二区三区久久精品| 97视频在线观看免费| 红桃av永久久久| 国产精品精品一区二区三区午夜版| 一个人看的www欧美| 亚洲欧美精品一区| 57pao国产精品一区| 国产精品视频yy9099| 欧美成人h版在线观看| 欧美激情videos| 国产精品白嫩初高中害羞小美女| 中文字幕在线看视频国产欧美在线看完整| 色综合五月天导航| 色婷婷av一区二区三区在线观看| 96国产粉嫩美女| 日韩欧美国产一区二区| 亚洲视频在线观看网站| 亚洲一区二区免费| 96sao精品视频在线观看| www.日韩免费| 日韩一区二区久久久| 亚洲第一精品自拍| 国产亚洲欧美另类中文| 国产精品久久一| 久青草国产97香蕉在线视频| 国产在线观看91精品一区| 亚洲福利小视频| 亚洲偷熟乱区亚洲香蕉av| 91av在线播放| 国内精久久久久久久久久人| 精品成人乱色一区二区| 中文字幕亚洲图片| 8050国产精品久久久久久| 亚洲国产精彩中文乱码av| 欧美午夜视频在线观看| 色久欧美在线视频观看| 国模视频一区二区三区| 欧美日韩国产成人高清视频| 一本一本久久a久久精品综合小说| 国产偷亚洲偷欧美偷精品| 欧美日韩国产限制| 国产成人精品999| 亚洲成人久久久| 狠狠躁夜夜躁人人爽天天天天97| 日韩男女性生活视频| 91精品国产综合久久香蕉922| 性色av一区二区三区免费| 国产精品久久久久久久app| 欧美日韩一区二区三区| 911国产网站尤物在线观看| 亚洲美女在线看| 欧美综合在线观看| 国产精品一二区| 日韩av网站在线| 国产亚洲一区二区精品| 欧美性高潮床叫视频| 精品国偷自产在线视频99| 欧美日韩国产二区| 奇米4444一区二区三区| www欧美日韩| 国内免费久久久久久久久久久| 国内精品久久久久久影视8| 欧美激情影音先锋| 欧美又大又硬又粗bbbbb| 久久激情五月丁香伊人| 2021国产精品视频| 精品成人国产在线观看男人呻吟| 成人性生交大片免费观看嘿嘿视频| 色婷婷av一区二区三区在线观看| 久久精品色欧美aⅴ一区二区| 精品国产欧美成人夜夜嗨| 欧美日韩在线第一页| 久久精品小视频| 日韩成人在线观看| 亚洲电影免费观看高清完整版在线观看| 久久成年人视频| 久久天堂av综合合色| 最新国产精品亚洲| 国产精品视频中文字幕91| 日韩国产欧美精品一区二区三区| 亚洲一区二区中文字幕| 成人激情视频免费在线| 亚洲激情视频在线播放| 精品国产鲁一鲁一区二区张丽| 亚洲一区二区三区xxx视频| 国产精品久久久久久中文字| 精品成人乱色一区二区| 亚洲美女av网站| 国产精品美腿一区在线看| 久久全国免费视频| 欧美成人亚洲成人日韩成人| 日韩福利在线播放| 欧美日韩免费看| 亚洲人成网站在线播| 精品国产乱码久久久久酒店| 亚洲国产精品国自产拍av秋霞| 日韩美女免费观看| 成人免费视频在线观看超级碰| 欧美日本啪啪无遮挡网站| 国产ts人妖一区二区三区| 欧美激情videoshd| 日韩中文字幕视频在线观看| 国产女人18毛片水18精品| 亚洲精品美女免费| 欧美激情影音先锋| 日本精品久久久久久久| 日本精品久久电影| 国内精品模特av私拍在线观看| 亚洲一区二区久久久| 日韩国产欧美精品一区二区三区| 日韩动漫免费观看电视剧高清| 精品国产一区久久久| 中文字幕日韩精品有码视频| 8090成年在线看片午夜| 亚洲欧美国产一区二区三区| 欧美亚洲视频一区二区| 亚洲最大福利视频网| 1769国产精品| 在线视频日本亚洲性| 久久精品欧美视频| 欧美国产日韩在线| 69av在线视频| 久久久久久久999| 91精品久久久久久久久中文字幕| 亚洲人成绝费网站色www| 18久久久久久| 日韩在线视频免费观看高清中文| 法国裸体一区二区| 久久久人成影片一区二区三区观看| 91精品国产综合久久香蕉922| 精品久久久久久中文字幕一区奶水| 91在线视频精品| 久久精品青青大伊人av| 久久国产精品电影| 亚洲最新中文字幕| 欧美主播福利视频| 亚洲最大福利网| 久久久久久成人| 国产精品久久久久999| 亚洲第一国产精品| 亚洲欧美日韩国产中文| 亚洲精品第一页| 国产人妖伪娘一区91| 亚洲国产欧美一区二区三区同亚洲| 国产成人精品日本亚洲| 亚洲一品av免费观看| 91在线观看免费高清完整版在线观看| 欧美日韩国产在线播放| 欧美亚洲成人精品| 亚洲精品国产精品久久清纯直播| 欧美一级在线亚洲天堂| 日韩在线观看免费全集电视剧网站| 国产成人91久久精品| 亚洲人成在线电影| 国产精品日韩欧美| 国产不卡av在线| 欧美午夜精品久久久久久久| 久久成人国产精品| 国产精品视频久久| 亚洲黄一区二区|