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


复制代码 代码如下:

------------------------------------------------------------------------
-- 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,10485856,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,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'------索引删除结束------'
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;
......
......
------索引删除结束------
*/



相关阅读:
Oracle数据库迁移介绍
Jquery ajax不能解析json对象,报Invalid JSON错误的原因和解决方法
Joomla教程:jtablesession::Store Failed错误解决方法
PHP学习之整理字符串
WEB标准化的过渡方案
同一个帐号不能同时登陆的问题
无hack无js全兼容text-overflow-ellipsis效果
正则表达式中的特殊字符
加入跨子网路由 Windows Server 2008 VPN
如何用javascript防止连打
一个UBB的PHP类
JS教程:理解JavaScript闭包
Vista系统下IE8有N个进程
如何制作和使用Jffs2文件系统
快速导航
PHP MySQL HTML CSS JavaScript MSSQL AJAX .NET JSP Linux Mac ASP 服务器 SQL jQuery C# C++ java Android IOS oracle MongoDB SQLite wamp 交通频道 作文范文 比翼双飞梦里客,酒醒才知需随缘 和妈妈一起出差 我的落日 谁能给我幸福? 你真的了解我嘛 2015我爱我校演讲稿 《春天的音乐会》诗歌 秋姑娘作文 浅谈我国大型连锁超市营销策略 小故事,大哲理:一寸虫的生存哲学 群众路线第三次回头看工作情况报告 物我真意谁能参 校长师德师风事迹典型材料 市全面开展保持共产党员先进性教育活动总结 恋爱实习生 奇货可居造句 小学四年级作文350字:一个不懂事的孩子 谈人生 我们来自一故乡 何处路 睁开眼,你从来都不是一个人 情系牵牛花650字 经典个性说说短语:有一种爱,明知无前路,心却早已收不回来。 葡萄公主作文750字 路那么遥远,票那么难买,为什么你还要回家过年? 国庆节节日祝福语 2015年一年级小学生清明节演讲稿:先烈伴我成长 服务中心“五一”期间工作总结 忧愁的伤感句子 关于扫雪的作文200字300字 矛盾纠纷排查制度 小学六年级作文1200字:游南风古灶 当老师,很好 所谓宫萌伊所谓Sea作文700字 求职简历应注意哪些方面 2015班主任培训工作总结 体会错误作文1100字 公司技术部经理就职演讲稿 端午节祝福短信28 初中初一作文400字:喜羊羊与灰太狼之变形方便面 “挑灯夜谈”广播电视节目策划书 以后的以后在也没了你的陪伴 无故我撞进你的世界 介绍北京故宫 宇宙里有些什么(转载) 励志英语短文:Positive Thoughts 喻大华经典语录大全 《中秋咏月诗词三首》教学设计2 关于竞选的作文 干部工作总结

Copyright © 2016 phpStudy |