数据库中的delete 与drop的区别, 从下面的例子开始:
delete : delete from 表名 where 条件
drop : alter table 表名 drop 字段
drop table 表
drop可用于删除数据库(drop database 数据库名称)、删除数据表( use 数据库名称 drop table 数据表1名称,数据表2名)或删除数据表字段(use 数据库名称 alter table 数据表名称 drop column 字段名(列名称))。
值得注意的是:drop语句将删除表的结构、被依赖的约束(constrain),触发器(trigger),索引(index); 依赖于该表的存储过程/函数将保留,但是变为invalid状态.
Truncate用于删除数据表中的数据,仅数据表中的数据,不删除表( truncate table 数据表名称)。
Delete :删除数据表中的行,可以删除某一行,也可以在不删除数据表的情况下删除所有行(删除某一行:Delete from 数据表名称 where 列名称=值)。
1、在速度上,一般来说,drop> delete。
2、在使用drop时一定要注意,虽然可以恢复,但为了减少麻烦,还是要慎重。
3、如果想删除部分数据用delete,注意带上where子句,回滚段要足够大;如果和事务有关,或者想触发trigger,还是用delete
4、如果想删除表,当然用drop;