sql删除数据的三种方式
1、delete删除数据:delete from tablename 删除记录表中的记录,但是注意:删除记录并不能释放数据库里被占用的数据块表空间. 它只把那些被删除的数据块标成unused,删除的数据可以使用数据支持数据的回滚
delete语句是dml,这个操作会放到rollback segement中,事务提交之后才生效;如果有相应的trigger,执行的时候将被触发.
2、回滚数据的操作
(1)查询当前数据库的时间
select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual; |
(2)查询删除数据之前的数据
select * from 表名 as of timestamp to_timestamp('2018-07-11 16:12:11','yyyy-mm-dd hh24:mi:ss'); |
(3)恢复数据
flashback table 表名 to timestamp to_timestamp('2018-07-11 16:12:11','yyyy-mm-dd hh24:mi:ss'); |
(4)在恢复数据的时候有可能出现未启用行移,则添加一下语句
alter table 表名 enable row movement; |
3、drop,truncate删除数据,数据不能实现数据回滚,要慎用
drop语句将删除表的结构被依赖的约束(constrain),触发器(trigger),索引(index); 依赖于该表的存储过程/函数将保留,但是变为invalid状态.
truncate,drop是ddl, 操作立即生效,原数据不放到rollback segment中,不能回滚. 操作不触发trigger.
truncate 语句缺省情况下见空间释放到 minextents个 extent,除非使用reuse storage; truncate会将高水线复位(回到最开始).
4、速度,一般来说: drop>; truncate >; delete
5、安全性:小心使用drop 和truncate,尤其没有备份的时候.否则哭都来不及使用上,想删除部分数据行用delete,注意带上where子句. 回滚段要足够大.想删除表,当然用drop,想保留表而将所有数据删除. 如果和事务无关,用truncate即可. 如果和事务有关,或者想触发trigger,还是用delete.如果是整理表内部的碎片,可以用truncate跟上reuse stroage,再重新导入/插入数据
阅读更多- 【MS SQL Server】SQL删除数据的各种方式总结
- 三种方式sql 插入多行数据
- Hibernate三种数据操作方式HQL-Criteria-Sql
- SQL删除多表关联数据的三种方法
- sql server中三种导入导出数据方式(SQL语句、bcp、dts)
- Delphi 操作SQL 插入一万条数据 三种方式速度测试
- [SQL]SQL删除数据的各种方式总结
- SQL删除重复数据的五种方式
- sql有几种删除表数据的方式
- SQL获取插入后数据ID的三种方式比较
- SQL删除数据的各种方式总结
- sql中的数据表三种连接方式
- SQL--删除表数据的三种不同实现方法
- SQL:使用备份向导、SQL命令、导出数据三种方式对已建立的数据库进行备份
- 通过SQL脚本导入数据到不同数据库避免重复导入三种方式
- MSSQLSERVER数据库- SQL删除重复数据的五种方式
- 通过SQL脚本导入数据到不同数据库避免重复导入三种方式
- 总结使用Get、Post、Socket三种方式连接服务端与传输数据的步骤
- SQL如何删除重复的数据行
- SQL 已更新或删除的行值要么不能使该行成为唯一行(sqlserver中有多行所有的列重复的数据,无法更新或删除问题)