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


复制代码 代码如下:

------------------------------------------------------------------------
-- 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 服务器 CMS SQL jQuery C# C++ java Android IOS oracle MongoDB PostgreSQL SQLite 交通频道 梅州-七台河 抚顺-宁海 巩义-丽水 长乐-信阳 攀枝花-随州 福清-扬中 珠海-贵阳 海口-海安 启东-鞍山 靖江-菏泽 漳州-滨州 怒江-天津 那曲-荣成 桐庐-合肥 辽阳-塔城 靖江-东台 临沧-台州 乌海-吐鲁番 资阳-长兴 蚌埠-温州 湛江-海城 遂宁-林芝 十堰-衢州 汕尾-铜仁 崇左-晋中 兰州-淮安 滨州-福州 浏阳-洛阳 绥化-眉山 许昌-海东 广元-乳山 抚州-鞍山 自贡-临沧 西宁-鞍山 瑞安-曲靖 临汾-阜阳 西宁-锡林浩特 招远-张家港 楚雄-湛江 海南-菏泽 阳江-临夏 海西-库尔勒 郫县-杭州 石狮-都江堰 随州-靖江 怀化-鄂尔多斯 莱西-胶州 昆明-三河 湛江-克拉玛依 三明-菏泽 东台-三明 四平-府谷 衡阳-河津 临沧-胶州 丽水-温岭 上饶-太原 日喀则-松原 永康-恩施 鄂州-塔城 石狮-莱西 黄冈-河津 玉林-黄山 嘉兴-蚌埠 宁乡-自贡 遂宁-漯河 凉山-江门 烟台-洛阳 平凉-怒江 龙岩-南昌 渭南-新郑 宜都-遵义 襄阳-平湖 莆田-连云港 池州-双流 邹城-温州 郫县-邹城 渭南-威海 玉环-襄阳 周口-莱州 诸暨-厦门 黎塘-杭州 驻马店-哈尔滨西 石家庄北-定州 棋子湾-黄流 代县-原平 霞浦-南靖 库尔勒-郑州 南召-安顺 小雨谷-贵阳 三河县-彰武 扶余北-军粮城北 邵东-南召 泗水-济宁 成都-嘉峪关 长春-汉口 凯里南-娄底南 鹰潭-酉阳 亳州-萍乡 柳毛-白奎堡 六安-丹徒 渠县-靖边 丹东-李家 晏城-哈尔滨 日照-长垣 义乌-牡丹江 建设-乾安 子长-绥德 南京南-开原西 龙游-金华南 狮子营-西阳村 大同-闻喜 昆明-宣城 松原北-扶余 牙屯堡-南充北 杨陵-怀化 牙拉盖图-查干哈达 遂平-全州南 渭南-太谷 万源-衢州 原林-哈克 大乌苏-碧州 龙游-武义北 安阳-衡阳 咸宁-盘锦 郑州-广安 开原西-双城北 向塘-勉县 抚顺北-锦州 蒲城东-太原 宝鸡-天津 嵯岗-廊坊北 庆丰-四合永 鳌江-山海关 扎赉诺尔西-五龙背 锦州-天义 扶余-九江 阳谷-沟帮子 铁岭-三河县 烟台-金华 银镇-隆化 遵义-元田坝 青岛-昆山南 天镇-察素齐 南充-岳池 福鼎-宁德 麻城北-惠山 商丘南-盘锦 邢台-商丘 呼和浩特-萨拉齐 梅河口-廊坊北 峻德-勃利 阳谷-兴城 廉江-化州 上海虹桥-乐清 唐山-横峰 扬州-全椒 费县-许昌 宁德-江宁 鞍山-海北 西安-岱岳

Copyright © 2016 phpStudy |