在SQL中删除表的内容和删除表的结构有什么不同?各自用什么命令语言?
1个回答
展开全部
区别有以下两点:
1、定义不同。
删除表的内容是指删除表的数据。表的结构还在。
删除表的结构是指删除整个表,包括结构和数据。
2、命令不同。
删除表的内容:
truncate table 表名称;
或者
delete from 表名称;
删除表结构:
drop table 表名称;
扩展资料:
truncate:删除内容、释放空间但不删除定义(保留表的数据结构)。truncate 不能删除行数据,要删就要把表清空。
delete:delete 语句用于删除表中的行。delete语句执行删除的过程是每次从表中删除一行,并且同时将该行的删除操作作为事务记录在日志中保存,以便进行进行回滚操作。
truncate与不带where的delete :只删除数据,而不删除表的结构(定义)。
如果想保留标识计数值,请改用delete。 如果要删除表定义及其数据,请使用 drop table 语句。
drop:删除内容和定义,释放空间。简单来说就是把整个表去掉。以后是不能新增数据,除非新增一个表。
drop语句将删除表的结构被依赖的约束(constrain),触发器(trigger),索引(index);依赖于该表的存储过程/函数将被保留,但其状态会变为:invalid。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询