手机
当前位置:查字典教程网 >编程开发 >mssql数据库 >找出所有非xml索引并重新整理的sql
找出所有非xml索引并重新整理的sql
摘要:复制代码代码如下:DECLAREcurCURSORFORSELECT[object_name]=s.name+'.'+OBJECT_NAME...

复制代码 代码如下:

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

【找出所有非xml索引并重新整理的sql】相关文章:

Microsoft SQLServer的版本区别及选择

SQLServre中的控制流语句

SQL查询日志 查看数据库历史查询记录的方法

HeadFirstSQL:学习笔记2/2

SQL Server导入、导出、备份数据方法

sqlserver如何从外网通过IP连接

SQL Server 大量数据的分页存储过程代码

DBNull和Null的区别

SQL SERVER修复系统表错误不匹配的问题

比较详细的完美解决安装sql2000时出现以前的某个程序安装已在安装计算机上创建挂起的文件操作。 原创

精品推荐
分类导航