加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

SQL Server 找出所有非xml索引并重新整理的sql

发布时间:2020-12-12 07:51:11 所属栏目:MsSql教程 来源:网络整理
导读:感兴趣的小伙伴,下面一起跟随编程之家 jb51.cc的小编两巴掌来看看吧! 代码如下: DECLARE cur CURSOR FOR SELECT [object_name]=s.name+.+OBJECT_NAME(A.object_id),B.name FROM sys.dm_db_index_physical_stats(DB_ID(AdventureWorks),NULL,null,null) AS

感兴趣的小伙伴,下面一起跟随编程之家 52php.cn的小编两巴掌来看看吧!

 

代码如下:


DECLARE cur CURSOR FOR 
SELECT 
[object_name]=s.name+'.'+OBJECT_NAME(A.object_id),B.name 
FROM sys.dm_db_index_physical_stats(DB_ID('AdventureWorks'),NULL,null,null) AS A 
JOIN sys.indexes AS B 
ON A.[object_id]=B.[object_id] 
AND A.[index_id]=B.[index_id] 
JOIN sys.objects AS o 
ON A.[object_id]=o.[object_id] 
JOIN sys.schemas AS s 
ON o.[schema_id]=s.[schema_id] 
WHERE A.[index_id]>0 
AND NOT EXISTS( 
SELECT * 
FROM sys.xml_indexes 
WHERE A.[object_id]=[object_id] 
AND A.[index_id]=[index_id] 
); 
OPEN cur; 
DECLARE @objname varchar(128),@indname varchar(128); 
DECLARE @sql nvarchar(4000); 
FETCH NEXT FROM cur INTO @objname,@indname; 
--重整所有索引,在这里先不管索引的碎片程度 
WHILE @@FETCH_STATUS=0 
BEGIN 
SET @sql='ALTER INDEX '+@indname+' ON '+@objname+' REBUILD'; 
EXEC(@sql); 
FETCH NEXT FROM cur INTO @objname,@indname; 
END 
CLOSE cur; 
DEALLOCATE cur; 

 

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读