SQL刪除資料庫中所有使用者資料表主鍵

來源:互聯網
上載者:User

--SQL刪除資料庫中所有使用者資料表主鍵

--查詢刪除前的當前資料庫所有約束
select * from information_schema.key_column_usage

declare @TableName nvarchar(250)
--聲明讀取資料庫所有資料表名稱遊標mycursor1
declare mycursor1 cursor for select name from dbo.SysObjects WHERE OBJECTPROPERTY(ID, 'ISUSErTable') = 1
 --開啟遊標
open mycursor1
--從遊標裡取出資料賦值到我們剛才聲明的資料表名變數中
fetch next from mycursor1 into @TableName
--如果遊標執行成功 
while (@@fetch_status=0)
begin 
 --定義當前主鍵約束變數
declare @ConstraintName varchar (200)

--刪除當前資料表的所有主鍵約束

--聲明讀取資料表所有主鍵約束名稱遊標mycursor2
declare mycursor2 cursor for select name from dbo.sysobjects where Xtype = 'PK' and Parent_Obj = (select [ID]  from dbo.sysobjects where id = object_id(N'['+@TableName+']')  and OBJECTPROPERTY(id, N'IsUserTable') = 1)
--開啟遊標
open mycursor2
--從遊標裡取出資料賦值到主鍵約束名稱變數中
fetch next from mycursor2 into @ConstraintName
--如果遊標執行成功 
while (@@fetch_status=0)
begin
--刪除當前找到的主鍵
exec ('ALTER TABLE ['+@TableName+'] DROP CONSTRAINT ['+@ConstraintName+']')
--print 'ALTER TABLE ['+@TableName+'] DROP CONSTRAINT ['+@ConstraintName+']'
--用遊標去取下一條記錄
fetch next from mycursor2 into @ConstraintName
end

--關閉遊標
close mycursor2
--撤銷遊標
deallocate mycursor2

 --用遊標去取下一條記錄
    fetch next from mycursor1 into @TableName
end

--關閉遊標
close mycursor1
--撤銷遊標
deallocate mycursor1

--查詢刪除後的當前資料庫所有約束
select * from information_schema.key_column_usage

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.