不用知道SQL Server表名就可以刪除該表以外的所有表
作者:佚名
如果想刪除某表以外的所有表,但是卻不知道該表的表明,還能不能實現(xiàn)呢?答案是肯定的。下面就教您這種方法,供你參考。
想刪除除表a以外的所有表,但是并不知道想刪除表A的SQL Server表名,實現(xiàn)這樣功能的語句應(yīng)該如何寫呢?下面就為您介紹這種不用知道SQL Server表名就可以刪除該表以外的所有表的方法,供您參考。
--首先要刪除表,就要刪除它的外鍵約束
- while(11=1)
- begin
- declare @exit int --判斷是否還有外鍵約束
- declare @constr_id varchar(200) --獲取外鍵約束的ID
- declare @table_id varchar(200) --獲取設(shè)外鍵的表的ID
- declare @table varchar --獲取設(shè)外鍵的表名
- declare @constr_name varchar(100) --獲取約束名
- declare @str varchar(100) --刪除表語句字符串
- declare @drop_constr varchar(100) --刪除約束字符串
- declare @conn_str varchar(2000) --將刪除語句連接起來的字符串
- select top 1 @constr_id=id,@constr_name=name from sysobjects where type='f'
- select @table_id=fkeyid from sysforeignkeys where constid=@constr_id
- select @table=name from sysobjects where id=@table_id
- select @exit=count(*) from sysobjects where type='f'
- if(@exit!=0)
- begin
- set @str='alter table'
- set @drop_constr='drop constraint'
- set @conn_str=@str+' '+@table+' '+@drop_constr+' '+@constr_name
- exec(@conn_str)
- end
- else
- break
- end
- if exists(select * from sysobjects where name='proc_drop_table' and type='p')
- drop proc proc_drop_table
- go
- create proc proc_drop_table
- @table_name varchar(200) --指定你不想刪除的表名
- as
- while(11=1)
- begin
- declare @str varchar(200)
- declare @exit int
- set @str='drop table'
- select top 1 @str=@str+' '+name from sysobjects where type='u' and name!=@table_name
- select @exit=count(*) from sysobjects where type='u' and name!=@table_name
- print @str
- if(@exit!=0)
- exec(@str)
- else
- begin
- break
- return
- end
- end
- go
- exec proc_drop_table a
以上就是不用知道SQL Server表名就可以刪除該表以外的所有表的方法介紹。
【編輯推薦】
責(zé)任編輯:段燃
來源:
互聯(lián)網(wǎng)