一个删除指定表的所有索引和统计的过程

sql2005 一个删除指定表的所有索引和统计的过程

<div class=”codetitle”><a style=”CURSOR: pointer” data=”83100″ class=”copybut” id=”copybut83100″ onclick=”doCopy(‘code83100’)”> 代码如下:<div class=”codebody” id=”code83100″>
————————————————————————
— Author : HappyFlyStone
— Date : 2009-09-05 00:57:10
— Version: Microsoft SQL Server 2005 – 9.00.2047.00 (Intel X86)
— Apr 14 2006 01:12:25
— Copyright (c) 1988-2005 Microsoft Corporation
— Enterprise Edition on Windows NT 5.2 (Build 3790: Service Pack 2)

————————————————————————
IF EXISTS (SELECT name FROM sysobjects WHERE id = OBJECT_ID(‘sp_DropAllIndex’)
AND OBJECTPROPERTY(OBJECT_ID(‘sp_DropAllIndex’),’IsProcedure’)=1)
DROP PROCEDURE sp_DropAllIndex
GO
CREATE PROCEDURE sp_DropAllIndex
@tabname nvarchar(150) — 需要删除统计或索引的表
AS
BEGIN
DECLARE @drop_idx_string nvarchar(4000) — 存放动态组织而成的DROPS index/stats 语法
SET NOCOUNT ON
— check table
IF NOT EXISTS (SELECT 1
FROM INFORMATION_SCHEMA.TABLES
WHERE table_type = ‘base table’ AND table_name = @tabname)
BEGIN
RAISERROR(N’——当前表:”%s” 不存在!’,16,1,@tabname)
RETURN (1)
END
SET @tabname = OBJECT_ID(@tabname)
IF EXISTS (SELECT 1
FROM sysindexes
WHERE id=@tabname AND indid BETWEEN 1 AND 254
AND status IN (96,10485856,8388704))
BEGIN
SELECT @drop_idx_string = isnull(@drop_idx_string+’;’,”)
+ (‘DROP STATISTICS ‘+OBJECT_NAME(@tabname)+’.’+name)
FROM sysindexes
WHERE id=@tabname AND indid BETWEEN 1 AND 254
AND status IN (96,8388704)
END
IF Len(@drop_idx_string) > 0
BEGIN
PRINT N’——统计删除列表——‘
PRINT @drop_idx_string+’;’
EXECUTE(@drop_idx_string+’;’)
PRINT N’——统计删除结束——‘
END
IF EXISTS (SELECT 1 FROM sysindexes
WHERE id=@tabname AND indid BETWEEN 1 AND 254
AND status NOT IN (96,8388704))
BEGIN
SET @drop_idx_string = NULL
select @drop_idx_string = isnull(@drop_idx_string+’;’+CHAR(13)+CHAR(10),”)
+ (‘DROP INDEX ‘+OBJECT_NAME(@tabname)+’.’+name)
FROM sysindexes
WHERE id=@tabname AND indid BETWEEN 1 AND 254
AND status NOT IN (96,8388704)
AND OBJECTPROPERTY (OBJECT_ID(name),’IsConstraint’) IS NULL–过程不处理CONSTRAINTS
END
PRINT N’——索引删除列表——‘
PRINT (@drop_idx_string+’;’)
EXEC( @drop_idx_string+’;’)
PRINT (‘……’+CHAR(13)+CHAR(10)+’……’)
PRINT N’——索引删除结束——‘
END
GO
create clustered index idx_id on ta(id)
create index idx_col on ta(col)
go
sp_DropAllIndex ‘ta’
/
——索引删除列表——
DROP INDEX ta.idx_id;
DROP INDEX ta.idx_col;
……
……
——索引删除结束——
/

作者: dawei

【声明】:永州站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。

为您推荐

联系我们

联系我们

0577-28828765

在线咨询: QQ交谈

邮箱: xwei067@foxmail.com

工作时间:周一至周五,9:00-17:30,节假日休息

返回顶部