一個刪除指定表的所有索引和統(tǒng)計的過程
更新時間:2009年09月06日 01:07:42 作者:
sql2005 一個刪除指定表的所有索引和統(tǒng)計的過程
復制代碼 代碼如下:
------------------------------------------------------------------------
-- 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) -- 需要刪除統(tǒng)計或索引的表
AS
BEGIN
DECLARE @drop_idx_string nvarchar(4000) -- 存放動態(tài)組織而成的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,10485856,8388704)
END
IF Len(@drop_idx_string) > 0
BEGIN
PRINT N'------統(tǒng)計刪除列表------'
PRINT @drop_idx_string+';'
EXECUTE(@drop_idx_string+';')
PRINT N'------統(tǒng)計刪除結(jié)束------'
END
IF EXISTS (SELECT 1 FROM sysindexes
WHERE id=@tabname AND indid BETWEEN 1 AND 254
AND status NOT IN (96,10485856,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,10485856,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'------索引刪除結(jié)束------'
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;
......
......
------索引刪除結(jié)束------
*/
相關(guān)文章
sqlserver2005自動創(chuàng)建數(shù)據(jù)表和自動添加某個字段索引
C#編程程序的時候,讓程序自動創(chuàng)建數(shù)據(jù)表,然后給數(shù)據(jù)表添加索引,這個方法是在百度百科找到,我自已只是簡單的修改了一下2012-06-06
sql2005 數(shù)據(jù)庫轉(zhuǎn)為sql2000數(shù)據(jù)庫的方法(數(shù)據(jù)導出導入)
今天一網(wǎng)友問我如何將sql2005數(shù)據(jù)庫轉(zhuǎn)換為sql2000,因為sql2005不如用sql2000更簡單與熟悉,其實就是通過數(shù)據(jù)導出導入的方法即可,這里分享下方便需要的朋友2012-11-11
SqlServer 2005中使用row_number()在一個查詢中刪除重復記錄
在SqlServer2005中,提供了一個row_number()的函數(shù),我們經(jīng)常用它做DataBase數(shù)據(jù)分頁.2010-09-09
如何在SQL Server 2005數(shù)據(jù)庫中導入SQL Server 2008的數(shù)據(jù)
在SQL Server 2008中導入SQL Server 2005很方便,高版本是可以向低版本兼容的,那么我們?nèi)绾卧赟QL Server 2005數(shù)據(jù)庫中導入SQL Server 2008的數(shù)據(jù)呢?下面我們來探討下:2014-06-06
SQL Server 數(shù)據(jù)庫清除日志的方法
SQLSERVER的數(shù)據(jù)庫日志占用很大的空間,下面提供三種方法用于清除無用的數(shù)據(jù)庫日志文件2012-07-07
SQL 2005使用專用管理員連接(DAC)的技巧及修改系統(tǒng)表的方法
SQL Server 2005 為管理員提供了一種特殊的診斷連接,以供在無法與服務器建立標準連接時使用。2011-07-07
sqlserver2005 master與msdb數(shù)據(jù)庫備份恢復過程
master與msdb數(shù)據(jù)庫的備份與普通數(shù)據(jù)庫一樣,恢復master與msdb數(shù)據(jù)庫關(guān)鍵在于以單用戶模式啟動,其它并沒有太大的區(qū)別,下面詳細說明使用方法2014-01-01
SQL2005查詢表結(jié)構(gòu)的SQL語句使用分享
分享一個SQL2005查詢表結(jié)構(gòu)的SQL語句,大家參考使用吧2013-11-11

