sql删除数据库表数据
1. SQL删除数据库中的所有数据
删除数据库的所有数据,因为数据之间可能形成相互约束关系,删除操作可能陷入死循环,因此可使用微软未正式公开的sp_MSForEachTable存储过程
sp_MSForEachTable参数说明:
@command1 nvarchar(2000), --第一条运行的SQL指令
@replacechar nchar(1) = N'?', --指定的占位符号
@command2 nvarchar(2000)= null, --第二条运行的SQL指令
@command3 nvarchar(2000)= null, --第三条运行的SQL指令
@whereand nvarchar(2000)= null, --可选条件来选择表
@precommand nvarchar(2000)= null, --执行指令前的操作(类似控件的触发前的操作)
@postcommand nvarchar(2000)= null --执行指令后的操作(类似控件的触发后的操作)
--删除当前数据库所有表中的数据
sp_MSforeachtable @command1='Delete from ?'
sp_MSforeachtable @command1 = "TRUNCATE TABLE ?"
2. SQL中删除表中的内容
(1)如果想清空表里面的内容可以使用:delete from KF;
(2)如果是想删除整个表可以使用:drop table KF。
SQL中删除表中的所有数据的方法:
1、TRUNCATE TABLE 删除表中的所有行,而不记录单个行删除操作。
(1)语法:TRUNCATE TABLE name;
(2)参数 name 是要截断的表的名称或要删除其全部行的表的名称。
2、DELETE语句,属于计算机软件领域,是编程中实现删除功能的命令。
(1)DELETE语句:用于创建一个删除查询,可从列在 FROM 子句之中的一个或多个表中删除记录,且该子句满足 WHERE 子句中的条件,可以使用DELETE删除多个记录。
(2)语法:DELETE [table.*] FROM table WHERE criteria;
(3)说明:table参数用于指定从其中删除记录的表的名称。
(4)criteria参数为一个表达式,用于指定哪些记录应该被删除的表达式。
(5)可以使用 Execute 方法与一个 DROP 语句从数据库中放弃整个表。不过,若用这种方法删除表,将会失去表的结构。不同的是当使用 DELETE,只有数据会被删除;表的结构以及表的所有属性仍然保留,例如字段属性及索引。
(2)sql删除数据库表数据扩展阅读:
1、SQL 的支持标准:
(1)SQL 是1986年10 月由美国国家标准局(ANSI)通过的数据库语言美国标准,接着,国际标准化组织(ISO)颁布了SQL正式国际标准。
(2)1989年4月,ISO提出了具有完整性特征的SQL89标准,1992年11月又公布了SQL92标准,在此标准中,把数据库分为三个级别:基本集、标准集和完全集。
2、数据库对象——表格:
(1)数据库中的表与我们日常生活中使用的表格类似,它也是由行(Row) 和列(Column)组成的。列由同类的信息组成,每列又称为一个字段,每列的标题称为字段名。
(2)行包括了若干列信息项。一行数据称为一个或一条记录,它表达有一定意义的信息组合。一个数据库表由一条或多条记录组成,没有记录的表称为空表。每个表中通常都有一个主关键字,用于唯一地确定一条记录。
参考资料来源:
网络-结构化查询语言
网络-DELETE语句
网络-数据库对象
3. sql怎么删除表中一行数据
首先你要确定能够唯一确定你那一行数据的字段或字段组合是哪些,
DELETE
FROM
表名
WHERE
字段1
=
‘’
and
字段2
=
‘’
and
...
字段1,...为能够唯一确定某一行数据的字段组合,‘’中填写你要删除的字段具体值就可以了
如果有主键,则直接利用主键确定某一行就可以了。
DELETE
FROM
表名
WHERE
主键
=
‘具体值’
4. 将SQL一个数据库中所有的表中的数据删除
use
数据库名
exec
sp_msforeachtable
"drop
table
?"
--这个操来作比较危险,删除自该数据库下的所有表。不知道是不是你要的结果
如果是只删除数据的话
CREATE
PROCEDURE
sp_DeleteAllData
AS
EXEC
sp_MSForEachTable
'ALTER
TABLE
?
NOCHECK
CONSTRAINT
ALL'--禁用约束
EXEC
sp_MSForEachTable
'ALTER
TABLE
?
DISABLE
TRIGGER
ALL'--禁用触发器
EXEC
sp_MSForEachTable
'DELETE
FROM
?'--清数据
EXEC
sp_MSForEachTable
'ALTER
TABLE
?
CHECK
CONSTRAINT
ALL'--还原约束
EXEC
sp_MSForEachTable
'ALTER
TABLE
?
ENABLE
TRIGGER
ALL'--还原触发器
EXEC
sp_MSFOREACHTABLE
'SELECT
*
FROM
?'--检查表内数据
GO
exec
sp_DeleteAllData
5. sql怎么删除表中一行数据
首先你要确定能够唯一确定你那一行数据的字段或字段组合是哪些,DELETE FROM 表名 WHERE 字段1 = ‘’ and 字段2 = ”,为能够唯一确定某一行数据的字段组合,‘’中填写你要删除的字段具体值就可以了,如果有主键,则直接利用主键确定某一行就可以了。DELETE FROM 表名 WHERE 主键 = ‘具体值’。
6. 如何清除SQL数据库中的数据
方法一:Delete Form 表名
方法二:TRUNCATE TABLE
在功能上与不带 WHERE 子句的 DELETE 语句相同:二者均删除表中的全部行。但 TRUNCATE TABLE 比 DELETE 速度快,且使用的系统和事务日志资源少。
DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项。TRUNCATE TABLE 通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放。
TRUNCATE TABLE 删除表中的所有行,但表结构及其列、约束、索引等保持不变。新行标识所用的计数值重置为该列的种子。如果想保留标识计数值,请改用 DELETE。如果要删除表定义及其数据,请使用 DROP TABLE 语句。
对于由 FOREIGN KEY 约束引用的表,不能使用 TRUNCATE TABLE,而应使用不带 WHERE 子句的 DELETE 语句。由于 TRUNCATE TABLE 不记录在日志中,所以它不能激活触发器。
TRUNCATE TABLE 不能用于参与了索引视图的表。
贴过来的,但是很全面
一般就是DLEETE from 表
7. sql删除数据库数据表
ACCESS 用 SQL语句 删除 数据表;
假设 数据表名 是 “工资表”,用SQL语句 删除“工资表”可专执行下面两属行语句:
SQL = "Drop table 工资表"
DoCmd.RunSQL SQL
当然,也可以用 DAO 删除数据表,语句如下:
CurrentDb.TableDefs.Delete "工资表"
8. sql删除数据库所有表
1.搜索出所有表名,构造为一条SQL语句 declare @trun_name varchar(8000)
set @trun_name=''
select @trun_name=@trun_name + 'truncate table ' + [name] + ' ' from sysobjects where xtype='U' and status > 0
exec (@trun_name)该方法适合表不是非常多的情况,否则表数量过多,超过字符串的长度,不能进行完全清理. 2.利用游标清理所有表 declare @trun_name varchar(50)
declare name_cursor cursor for
select 'truncate table ' + name from sysobjects where xtype='U' and status > 0
open name_cursor
fetch next from name_cursor into @trun_name
while @@FETCH_STATUS = 0
begin
exec (@trun_name)
print 'truncated table ' + @trun_name
fetch next from name_cursor into @trun_name
end
close name_cursor
deallocate name_cursor
这是我自己构造的,可以做为存储过程调用, 能够一次清空所有表的数据,并且还可以进行有选择的清空表. 3.利用微软未公开的存储过程 exec sp_msforeachtable "truncate table ?"