• 企业400电话
  • 网络优化推广
  • AI电话机器人
  • 呼叫中心
  • 全 部 栏 目

    网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    一个删除指定表的所有索引和统计的过程
    POST TIME:2021-10-18 22:50
    复制代码 代码如下:

    ------------------------------------------------------------------------
    -- 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;
    ......
    ......
    ------索引删除结束------
    */
    上一篇:SQLServer Job运行成功或失败时发送电子邮件通知的图文教程
    下一篇:SQLServer2005 的查询独占模拟
  • 相关文章
  • 

    关于我们 | 付款方式 | 荣誉资质 | 业务提交 | 代理合作


    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    X

    截屏,微信识别二维码

    微信号:veteran88

    (点击微信号复制,添加好友)

     打开微信