SCN:system Change Number /system commit number : 系统修改号/系统提交号,scn是oracle内部时钟,每次发生提交的时候,这个时钟(scn)都会自动滴答(递增更新),这个scn很容易得到:
declare
v_scn number;
begin
exec v_scn:= dbms_flashback.get_system_change_number;
dbms_put.put_line('scn:' || v_scn);
end;
有了scn,我们就可以告诉oracle我们要查询的时间点,以后查询的时候,就可以只看这个时间点上的数据:
select count(0) from t_name;
count(0)
--------------
100
然后我们把这个表的数据给删掉,并且进行提交:
delete from t_name;
commit;
select count(0) from t_name;
count(0)
--------------
0
不过使用闪回查询(as of scn /as of timestamp)可以让oracle告诉我们,这个时间点上的数据:
select count(*), :v_scn then_scn,dbms_flashback.get_system_change_number now_scn from t_name as of scn :v_scn;
count(*) then_scn now_scn
-------------------------------------
100 65465 65466
通过scn时间点的查询,能获取到那个时间点上版本的数据 count=100;
分享到:
相关推荐
### MySQL与Oracle数据库的主要区别 #### 一、并发性 **MySQL**的并发处理主要依赖于不同的存储引擎。...总体而言,MySQL在SQL语句的便捷性和灵活性方面更具优势,而Oracle则在数据一致性、并发处理等方面更为强大。
Oracle数据库通过多种机制保证读一致性的同时,还能实现非阻塞读。 **1. 读一致性:** 读一致性是指查询过程中看到的数据状态始终如一。Oracle通过多版本并发控制(MVCC)机制来实现这一特性,即每个事务都能看到其...
- **一致性读**:Oracle提供了一种称为“一致性读”的特性,使得用户可以在不阻塞其他事务的情况下读取数据。 #### 14. 可管理性 - **自动管理**:Oracle通过自动诊断资源管理器(ADDM)等工具提供了自动化管理的...
Oracle数据库采用多版本读一致性(Multi-Version Read Consistency)机制,允许不同事务同时读取同一数据的不同版本。这避免了读取操作对写入操作的阻塞,提升了并发处理能力。具体而言,当一个事务开始时,它可以看到...
多版本并发控制是Oracle的核心,保证了事务的一致性和并发性。游标管理与数据量无关,它在打开时确定了获取的数据,不受后续数据变化的影响。 总的来说,Oracle数据库的学习和优化是一个持续的过程,需要深入理解...
- Oracle通过锁和多版本并发控制来平衡并发性和数据一致性。锁机制防止数据冲突,而MVCC允许非阻塞读取,提高了并发性能。 - SET TRANSACTION语句允许设置事务的隔离级别,以适应不同的应用需求。例如,READ ONLY...
- **分布式事务**:探讨了跨多个数据库或资源管理器的事务处理机制,以及Oracle如何支持这类复杂场景下的事务一致性。 ### 5. 重做与回滚 - **重做日志**:阐述了重做日志在事务提交过程中的作用,以及它是如何...
9. **锁信息**:非进程控制的锁信息,例如用于保护数据一致性的一些内部锁。 ##### SGA的重要参数: - **DB_CACHE_SIZE**:设置数据缓冲区的大小。 - **LOG_BUFFER**:设置重做日志缓冲区的大小。 - **SHARED_POOL...
4. **多版本并发控制(MVCC)**:Oracle的Read Committed和Read Repeatable Read隔离级别利用MVCC实现非阻塞读操作,从而提高并发性能。 为了优化锁定性能,可以考虑以下策略: 1. **适当设计事务**:尽量减少事务...
Oracle通过使用回退段有效地避免了此类阻塞,确保事务间的独立性和一致性。 ### 外键约束 在处理外键约束时,SQL Server允许级联删除和级联更新,而Oracle仅支持级联删除。这意味着在SQL Server中,当主表中的记录...
- 讨论事务的特性,包括原子性、一致性、隔离性和持久性,以及多版本并发控制(MVCC)如何支持非阻塞读操作。 #### 分区与并行 - 阐释分区技术如何提高大型数据集的管理效率,以及并行处理如何加速数据处理速度。 #...
40. **读一致性和多版本并发控制**: - **读一致性**:保证不同事务读取的数据一致性。 - **多版本并发控制**:通过保留旧数据版本支持并发操作。 #### 三、高级知识(41-60) 41. **实例的启动与关闭过程**: ...
9. 异步操作:在VB.NET版本中,可以利用异步编程模型(如`Async`和`Await`关键字)实现非阻塞的数据库操作,提高用户体验。 10. Oracle特有函数:Oracle数据库提供了一些特有的函数,如TO_DATE、TO_CHAR等,VB代码...
- 锁:ORACLE使用锁来实现并发控制,确保数据的一致性。锁可以分为共享锁(读锁)和独占锁(写锁),防止多个事务同时修改同一数据。 3. 解决死锁的策略 - 预防死锁:通过合理设计事务的资源请求顺序,避免循环...
- **事务管理**: 在将数据保存到数据库时,可能需要使用事务来确保数据的一致性和完整性。 - **批量处理**: 如果数据量大,可以考虑批量插入,减少与数据库的交互次数,提高效率。 - **错误处理**: 必须处理任何...
在高并发和数据一致性要求高的场景下,事务控制至关重要。 6. **连接池管理**: 使用第三方库如C3P0、Apache DBCP或HikariCP创建连接池,提高连接复用,减少数据库资源消耗。 7. **性能优化**: 通过设置合适的连接...
2. **集群支持**:Oracle GRID Infrastructure依赖于`libaio`来提供高效的数据同步和通信机制,确保在集群环境中各个节点之间的数据一致性。 安装这两个RPM包的步骤如下: 1. 首先,确保你的Linux系统支持`i386`...