千家信息网

ROW ARCHIVE

发表于:2024-12-13 作者:千家信息网编辑
千家信息网最后更新 2024年12月13日,在一些场景中,当我们不需要表中的某些行时,需要发布delete语句来删除。但是有时候并不是想在物理上真正的删除这些数据,在传统的表设计中,我们一般都加多一个栏位来表示逻辑删除。比如is_delete,
千家信息网最后更新 2024年12月13日ROW ARCHIVE

在一些场景中,当我们不需要表中的某些行时,需要发布delete语句来删除。但是有时候并不是
想在物理上真正的删除这些数据,在传统的表设计中,我们一般都加多一个栏位来表示逻辑删除。
比如is_delete,当应用程序在处理时,把is_delete也加入到where条件中来表示行是不是真正的删除了.
在12C中,引入了一个新特性叫作row archive,可以让数据库自动来做这些操作.这个特性也叫作In-Database Archiving.

SQL> create table employees_test as select * from employees;

Table created.
SQL> select count(*) from employees_test where department_id=80;

COUNT(*)

    34

SQL> alter table employees_test row archival;

Table altered.

在允许row archival后,系统会自动会表增加栏位ORA_ARCHIVE_STATE,用来表示数据可用性情况



改变session变可见

0