赢友网络

删除指定数据库中的所有表

USE DC		-- 删除的表的数据库

--变量@tablename保存表名
declare @tablename nvarchar(100)

--将用户表全部保存到临时表#tablename中
SELECT [name] into #tablename FROM sysobjects
WHERE type = 'U';

--当#tablename有数据时
while(select count(1) from #tablename)>0
begin
--从#tablename中取第一条
select top 1 @tablename=[name] from #tablename;
--进行表删除操作,表名为变量,所以此处用到动态sql
exec('drop table '+@tablename);
--将此表名记录从#tablename中删除
delete from #tablename where [name]=@tablename;
end

--最后删除临时表#tablename
drop table #tablename

  

posted @ 2015-03-12 21:13  新生帝  阅读(644)  评论(0编辑  收藏  举报
赢友网络