SQLserver删除某数据库中所有表实现思路

 更新时间:2013年02月17日 17:05:41   作者:  
方便删除数据库中所有的数据表,清空数据库,有些有约束,不能直接delete,因为那样太危险了所以需要先删除库中的约束,接下来提供详细实现代码,感兴趣的你可以参考下哦,或许对你学习有所帮助

方便删除数据库中所有的数据表,清空数据库,有些有约束,不能直接delete,需要先删除库中的约束,代码如下

复制代码 代码如下:

--删除所有约束
DECLARE c1 cursor for
select'alter table ['+ object_name(parent_obj)+'] drop constraint ['+name+']; '
from sysobjects
where xtype ='F'
open c1
declare @c1 varchar(8000)
fetch nextfrom c1 into@c1
while(@@fetch_status=0)
begin
exec(@c1)
fetch nextfrom c1 into@c1
end
close c1
deallocate c1
--删除数据库所有表
declare @tname varchar(8000)
set@tname=''
select@tname=@tname+Name+','from sysobjects where xtype='U'
select@tname='drop table '+ left(@tname,len(@tname)-1)
exec(@tname)

然后清空数据库中的所有表
如果需要删除存储过程等只需要将上面的做如下修改就行了的where xtype='U' 改成 where xtype='P',drop table 改成 drop Procedure

sysobjects的xtype代表含义:

在数据库内创建的每个对象(约束、默认值、日志、规则、存储过程等)在表中占一行。只有在 tempdb 内,每个临时对象才在该表中占一行。

列名 数据类型 描述
name sysname 对象名。
Id int 对象标识号。
xtype char(2) 对象类型。可以是下列对象类型中的一种:
C = CHECK 约束
D = 默认值或 DEFAULT 约束
F = FOREIGN KEY 约束
L = 日志
FN = 标量函数
IF = 内嵌表函数
P = 存储过程
PK = PRIMARY KEY 约束(类型是 K)
RF = 复制筛选存储过程
S = 系统表
TF = 表函数
TR = 触发器
U = 用户表
UQ = UNIQUE 约束(类型是 K)
V = 视图
X = 扩展存储过程

uid smallint 所有者对象的用户 ID。
info smallint 保留。仅限内部使用。
status int 保留。仅限内部使用。
base_schema_
ver int 保留。仅限内部使用。
replinfo int 保留。供复制使用。
parent_obj int 父对象的对象标识号(例如,对于触发器或约束,该标识号为表 ID)。
crdate datetime 对象的创建日期。
ftcatid smallint 为全文索引注册的所有用户表的全文目录标识符,对于没有注册的所有用户表则为 0。
schema_ver int 版本号,该版本号在每次表的架构更改时都增加。
stats_schema_
ver int 保留。仅限内部使用。
type char(2) 对象类型。可以是下列值之一:
C = CHECK 约束
D = 默认值或 DEFAULT 约束
F = FOREIGN KEY 约束
FN = 标量函数
IF = 内嵌表函数
K = PRIMARY KEY 或 UNIQUE 约束
L = 日志
P = 存储过程
R = 规则
RF = 复制筛选存储过程
S = 系统表
TF = 表函数
TR = 触发器
U = 用户表
V = 视图
X = 扩展存储过程
userstat smallint 保留。
sysstat smallint 内部状态信息。
indexdel smallint 保留。
refdate datetime 留作以后使用。
version int 留作以后使用。
deltrig int 保留。
instrig int 保留。
updtrig int 保留。
seltrig int 保留。
category int 用于发布、约束和标识。
cache smallint 保留。

相关文章

  • SQL Server数据库备份加密的方法详解

    SQL Server数据库备份加密的方法详解

    在数据即资产的今天,保护数据库备份免受未授权访问是至关重要的,SQL Server提供了强大的安全特性,包括对数据库备份进行加密的能力,本文将深入探讨如何在SQL Server中实现数据库的自定义数据备份加密,需要的朋友可以参考下
    2024-08-08
  • case when then else end语句的用法(附demo)

    case when then else end语句的用法(附demo)

    本文主要介绍了case when then else end语句的用法,主要介绍了两种格式,简单case函数和case搜索函数,具有一定的参考价值,感兴趣的可以了解一下
    2023-10-10
  • SQL Server使用PIVOT与unPIVOT实现行列转换

    SQL Server使用PIVOT与unPIVOT实现行列转换

    这篇文章介绍了SQL Server使用PIVOT与unPIVOT实现行列转换的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • sql 自定义百分比转换小数函数代码

    sql 自定义百分比转换小数函数代码

    sqlserver中自定义百分比转换小数函数,需要的朋友可以参考下。
    2011-09-09
  • Sql Server 2000删除数据库备份文件

    Sql Server 2000删除数据库备份文件

    Sql Server 2000删除数据库备份文件的语句。
    2009-09-09
  • SQL Server数据库命令整理大全

    SQL Server数据库命令整理大全

    刚开始学数据库,可能一下子记不住那么多的命令,或者命令太多,容易混淆,不知道如何选择最合适的那一条,所以我在这里整理好了一份经常会用到的一些,这篇文章主要给大家介绍了关于SQL Server数据库命令整理大全的相关资料,需要的朋友可以参考下
    2024-05-05
  • SQL 复合查询条件(AND,OR,NOT)对NULL值的处理方法

    SQL 复合查询条件(AND,OR,NOT)对NULL值的处理方法

    在SQL的3值逻辑下,一个查询条件可以产生以下三种情况:TRUE,FALSE,NULL。只有那些满足WHERE子句的值是TRUE的记录才出现在结果表中。
    2011-04-04
  • GridView自定义分页的四种存储过程

    GridView自定义分页的四种存储过程

    首先要说说为什么不用GridView的默认的分页功能,GridView控件并非真正知道如何获得一个新页面,它只是请求绑定的数据源控件返回适合规定页面的行,分页最终是由数据源控件完成。
    2009-12-12
  • SQL 平均数统计

    SQL 平均数统计

    sql下求列的平均数的语句
    2008-12-12
  • mssql SA帐号的改名和删除

    mssql SA帐号的改名和删除

    众所周知,在M$sql中有个绝对是网络安全中的隐患的帐号sa,系统管理员 (sa),默认情况下,它指派给固定服务器角色 sysadmin,并不能进行更改。这个sa一般情况下是既不可以更改名称,也不可以删除,呵呵,有点鸡肋的味道,弃置可惜,食之无味。装上sql2000之后,感觉怪怪的,放着这个后门在,始终都不放心,担心有一天被人破出密码,那偶的电脑不就完拉。可能你回说设个强壮点的密码,这个办法是可行,可不是长久之记,所谓斩草要除根,要是把sa给删拉就不用担心那些"黑客"暴力破解拉。
    2008-04-04

最新评论