zoukankan      html  css  js  c++  java
  • sql删除数据库存储过程,约束,函数,索引等

    代码
    --删除存储过程
    DECLARE @STRING VARCHAR(8000)
    WHILE EXISTS(SELECT NAME FROM SYSOBJECTS WHERE TYPE='P' AND STATUS>=0)
    BEGIN
    SELECT @STRING='DROP PROCEDURE '+NAME FROM SYSOBJECTS WHERE TYPE = 'P' AND STATUS>=0
    --SELECT @STRING
    EXEC(@STRING)
    END

    GO

    --默认值或 DEFAULT 约束
    DECLARE @STRING VARCHAR(8000)
    WHILE EXISTS(SELECT NAME FROM SYSOBJECTS WHERE XTYPE='D')
    BEGIN
    SELECT @STRING='ALTER TABLE '+B.NAME+' DROP CONSTRAINT '+A.NAME
    FROM (SELECT PARENT_OBJ,NAME FROM SYSOBJECTS WHERE XTYPE='D') A,
    (
    SELECT ID,NAME FROM SYSOBJECTS WHERE OBJECTPROPERTY(ID, N'ISUSERTABLE'= 1) B
    WHERE A.PARENT_OBJ=B.ID
    EXEC(@STRING)
    END

    GO

    --UNIQUE 约束
    DECLARE @STRING VARCHAR(8000)
    WHILE EXISTS(SELECT NAME FROM SYSOBJECTS WHERE XTYPE='UQ')
    BEGIN
    SELECT @STRING='ALTER TABLE '+B.NAME+' DROP CONSTRAINT '+A.NAME
    FROM (SELECT PARENT_OBJ,NAME FROM SYSOBJECTS WHERE XTYPE='UQ') A,
    (
    SELECT ID,NAME FROM SYSOBJECTS WHERE OBJECTPROPERTY(ID, N'ISUSERTABLE'= 1) B
    WHERE A.PARENT_OBJ=B.ID
    EXEC(@STRING)
    END

    GO

    --FOREIGN KEY 约束
    DECLARE @STRING VARCHAR(8000)
    WHILE EXISTS(SELECT NAME FROM SYSOBJECTS WHERE TYPE='F')
    BEGIN
    SELECT @STRING='ALTER TABLE '+B.NAME+' DROP CONSTRAINT '+A.NAME
    FROM (SELECT PARENT_OBJ,NAME FROM SYSOBJECTS WHERE TYPE='F') A,
    (
    SELECT ID,NAME FROM SYSOBJECTS WHERE OBJECTPROPERTY(ID, N'ISUSERTABLE'= 1) B
    WHERE A.PARENT_OBJ=B.ID
    EXEC(@STRING)
    END

    GO

    --PRIMARY KEY 约束
    DECLARE @STRING VARCHAR(8000)
    WHILE EXISTS(SELECT NAME FROM SYSOBJECTS WHERE XTYPE='PK')
    BEGIN
    SELECT @STRING='ALTER TABLE '+B.NAME+' DROP CONSTRAINT '+A.NAME
    FROM (SELECT PARENT_OBJ,NAME FROM SYSOBJECTS WHERE XTYPE='PK') A,
    (
    SELECT ID,NAME FROM SYSOBJECTS WHERE OBJECTPROPERTY(ID, N'ISUSERTABLE'= 1) B
    WHERE A.PARENT_OBJ=B.ID
    EXEC(@STRING)
    END

    GO

    --触发器
    DECLARE @STRING VARCHAR(8000)
    WHILE EXISTS(SELECT NAME FROM SYSOBJECTS WHERE XTYPE='TR')
    BEGIN
    SELECT @STRING='DROP TRIGGER '+NAME FROM SYSOBJECTS WHERE XTYPE='TR'
    EXEC(@STRING)
    END

    GO

     

    --索引
    declare @string varchar(8000)
    while exists(
    select TABLE_NAME= o.name,INDEX_NAME= x.name 
    from sysobjects o, sysindexes x, syscolumns c, sysindexkeys xk
    where o.type in ('U'
    and convert(bit,(x.status & 0x800)/0x800)=0
    and x.id = o.id
    and o.id = c.id
    and o.id = xk.id
    and x.indid = xk.indid
    and c.colid = xk.colid
    and xk.keyno <= x.keycnt
    and permissions(o.id, c.name) <> 0
    and (x.status&32= 0 -- No hypothetical indexes
    group by o.name,x.name)
    begin
    select top 1 @string='drop index '+o.name+'.'+ x.name 
    from sysobjects o, sysindexes x, syscolumns c, sysindexkeys xk
    where o.type in ('U'
    and convert(bit,(x.status & 0x800)/0x800)=0
    and x.id = o.id
    and o.id = c.id
    and o.id = xk.id
    and x.indid = xk.indid
    and c.colid = xk.colid
    and xk.keyno <= x.keycnt
    and permissions(o.id, c.name) <> 0
    and (x.status&32= 0 -- No hypothetical indexes
    group by o.name,x.name
    exec(@string)
    end

    GO 



  • 相关阅读:
    所有抽样单元都有相等的被选取机会 ,说法错误
    银行存款余额表由谁编制的
    资本公积——资本溢价与资本公积——其他资本公积
    货币单元抽祥
    企业安全生产费用账务的处理
    Tableau代写制作地图可视化和树形图、条形图
    Tableau 代写数据可视化:探索性图形分析新生儿死亡率数据
    R、Python代写、Open Refine采集pdf数据,清理数据和格式化数据
    使用GIS编程代写制作静态地图和处理地理数据
    用R语言编程代写制作交互式图表和地图
  • 原文地址:https://www.cnblogs.com/wenjl520/p/1951851.html
Copyright © 2011-2022 走看看