Oracle 多版本控制
来源:互联网 发布:python编程实例 编辑:程序博客网 时间:2024/04/29 13:06
SESSION 1:SQL> create table t 2 as 3 select * from all_users;Table created.SQL> variable x refcursorSQL> begin 2 open :x for select * from t; 3 end; 4 /PL/SQL procedure successfully completed.SESSION 2:SQL> delete from t;37 rows deleted.SQL> commit;Commit complete.SESSION 1:SQL> print xUSERNAME USER_ID CREATED------------------------------ ---------- ---------TEST 91 27-DEC-00BI 90 07-NOV-00PM 89 07-NOV-00SH 88 07-NOV-00IX 87 07-NOV-00OE 86 07-NOV-00HR 85 07-NOV-00SCOTT 84 13-AUG-09OWBSYS_AUDIT 83 13-AUG-09OWBSYS 79 13-AUG-09APEX_030200 78 13-AUG-09USERNAME USER_ID CREATED------------------------------ ---------- ---------APEX_PUBLIC_USER 76 13-AUG-09FLOWS_FILES 75 13-AUG-09MGMT_VIEW 74 13-AUG-09SYSMAN 72 13-AUG-09SPATIAL_CSW_ADMIN_USR 70 13-AUG-09SPATIAL_WFS_ADMIN_USR 67 13-AUG-09MDDATA 65 13-AUG-09MDSYS 57 13-AUG-09SI_INFORMTN_SCHEMA 56 13-AUG-09ORDPLUGINS 55 13-AUG-09ORDDATA 54 13-AUG-09USERNAME USER_ID CREATED------------------------------ ---------- ---------ORDSYS 53 13-AUG-09OLAPSYS 61 13-AUG-09ANONYMOUS 46 13-AUG-09XDB 45 13-AUG-09CTXSYS 43 13-AUG-09EXFSYS 42 13-AUG-09XS$NULL 2147483638 13-AUG-09WMSYS 32 13-AUG-09APPQOSSYS 31 13-AUG-09DBSNMP 30 13-AUG-09ORACLE_OCM 21 13-AUG-09USERNAME USER_ID CREATED------------------------------ ---------- ---------DIP 14 13-AUG-09OUTLN9 13-AUG-09SYSTEM5 13-AUG-09SYS0 13-AUG-0937 rows selected.在前面的例子中,我创建了一个测试表T,并把ALL_USERS 表的一些数据加载到这个表中。然后在这个表上打开一个游标。在此没有从该游标获取数据,只是打开游标而已。要记住,Oracle 并不“回答”这个查询。打开游标时,Oracle 不复制任何数据,你可以想想看,即使一个表有十亿条记录,是不是也能很快就打开游标?没错,游标会立即打开,它会边行进边回答查询。换句话说,只是在你获取数据时它才从表中读数据。在同一个会话中(或者也可以在另一个会话中;这同样能很好地工作),再从该表删除所有数据。甚至用COMMIT 提交了删除所做的工作。记录行都没有了,但是真的没有了吗?实际上,还是可以通过游标获取到数据。OPEN 命令返回的结果集在打开的那一刻(时间点)就已经确定。打开时,我们根本没有碰过表中的任何数据块,但答案已经是铁板钉钉的了。获取数据之前,我们无法知道答案会是什么;不过,从游标角度看,结果则是固定不变的。打开游标时,并非Oracle 将所有数据复制到另外某个位置;实际上是DELETE 命令为我们把数据保留下来,把它放在一个称为undo 段(undo segment)的数据区,这个数据区也称为回滚段(rollback segment)。
0 0
- Oracle 多版本控制
- Oracle的多版本控制小实验
- oracle事务处理中的版本控制
- Oracle中多版本控制的例子(MVCC)
- Oracle系列之七 并发与多版本控制
- 多版本并发控制
- 《Oracle编程艺术》学习笔记(13)-Oracle的并发与多版本控制
- 1.4. 多版本并发控制
- rvm ruby 多版本控制
- mysql多版本并发控制
- MVCC 多版本并发控制
- innodb的多版本控制
- python多版本控制操作方法
- 多版本并发控制MVCC
- 【MySQL】多版本并发控制
- ubuntu opencv多版本控制
- python的多版本控制
- 【mysql】--MVCC 多版本控制
- android popwindow使用(实现自定义下拉菜单)
- --寂地《踮脚张望的时光》
- 电子词典
- java web
- Androidpn的使用
- Oracle 多版本控制
- 为什么说Tomcat是一个Web服务器而不是一个应用服务器
- 改变Eclipse主题颜色
- 调试安装类
- Redhat 下安装程序包 Public key for *.rpm is not installed
- Unity3D美工需要知道的知识
- mssql 时间变成字符串
- Struts2 值栈
- 动态改变LinearLayout的背景