删除指定表的所有索引,包括主键索引,唯一索引

系统 1786 0
原文: 删除指定表的所有索引,包括主键索引,唯一索引和普通索引 ,适用于sql server 2005 .

删除指定表的所有索引,包括主键索引,唯一索引和普通索引 ,适用于sql server 2005,

使用说明 :

1,先执行脚本,将存储过程创建在数据库中

2,调用方法,以黄金搭档数据库为例

use velcromfm --数据库名, 根据具体项目替换

go

declare @tableName varchar(20)
set @tableName='menu' --表名 ,根据实际情况替换
exec sp_dropindex @tableName

3,如有需要,该脚本稍加改写就可以做成一个删除数据库所有索引的脚本

提供一个思路 :

select * from sysobjects where xtype='u' --查除数据库里所有的表,使用游标遍历执行这个存储过程

4,该脚本有个问题,如果某个pk索引是另外一个表的外键的话就删不掉,但在velcro系统的数据库不会有这个麻烦,应为我们的系统没有设任何外键^-^

脚本如下

*/

----------------------------- 脚本---------------------------------------------------


if exists(select 1 from sysobjects where id = object_id('sp_dropindex') and xtype = 'P')
drop procedure sp_dropindex
go

create procedure sp_dropindex @tableName varchar(50)=null --表名
as

if @tableName is null
begin
 raiserror('必须提供@tableName参数',12,1)
 return
end

create table # (
 id int identity,
 index_name varchar(50),
 index_description varchar(1000),
 index_keys varchar(100)
)

insert #(index_name,index_description,index_keys)
exec sp_helpindex @tableName

declare @i int
declare @sql varchar(100)
 
set @i = 1

while @i<=(select max(id) from #)
begin
 if exists(select 1 from sysobjects A join # B on A.name=B.index_name where B.id=@i and A.xtype in ('PK','UQ'))
 begin
  select @sql = 'alter table '+ @tableName +' drop constraint ' + (select index_name from # where id = @i)
 end
 else
 begin
  select @sql = 'drop index '+ @tableName + '.' + (select index_name from # where id=@i )
 end
 
-- print(@sql)
    exec(@sql) 
 set @i=@i+1
end

drop table #

go

删除指定表的所有索引,包括主键索引,唯一索引和普通索引 ,适用于sql server 2005 .


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论