SESSION 1:

SQL> create table t
2 as
3 select * from all_users; Table created. SQL> variable x refcursor
SQL> 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 x USERNAME USER_ID CREATED
------------------------------ ---------- ---------
TEST 91 27-DEC-00
BI 90 07-NOV-00
PM 89 07-NOV-00
SH 88 07-NOV-00
IX 87 07-NOV-00
OE 86 07-NOV-00
HR 85 07-NOV-00
SCOTT 84 13-AUG-09
OWBSYS_AUDIT 83 13-AUG-09
OWBSYS 79 13-AUG-09
APEX_030200 78 13-AUG-09 USERNAME USER_ID CREATED
------------------------------ ---------- ---------
APEX_PUBLIC_USER 76 13-AUG-09
FLOWS_FILES 75 13-AUG-09
MGMT_VIEW 74 13-AUG-09
SYSMAN 72 13-AUG-09
SPATIAL_CSW_ADMIN_USR 70 13-AUG-09
SPATIAL_WFS_ADMIN_USR 67 13-AUG-09
MDDATA 65 13-AUG-09
MDSYS 57 13-AUG-09
SI_INFORMTN_SCHEMA 56 13-AUG-09
ORDPLUGINS 55 13-AUG-09
ORDDATA 54 13-AUG-09 USERNAME USER_ID CREATED
------------------------------ ---------- ---------
ORDSYS 53 13-AUG-09
OLAPSYS 61 13-AUG-09
ANONYMOUS 46 13-AUG-09
XDB 45 13-AUG-09
CTXSYS 43 13-AUG-09
EXFSYS 42 13-AUG-09
XS$NULL 2147483638 13-AUG-09
WMSYS 32 13-AUG-09
APPQOSSYS 31 13-AUG-09
DBSNMP 30 13-AUG-09
ORACLE_OCM 21 13-AUG-09 USERNAME USER_ID CREATED
------------------------------ ---------- ---------
DIP 14 13-AUG-09
OUTLN 9 13-AUG-09
SYSTEM 5 13-AUG-09
SYS 0 13-AUG-09 37 rows selected. 在前面的例子中,我创建了一个测试表T,并把ALL_USERS 表的一些数据加载到这个表中。然后在这
个表上打开一个游标。在此没有从该游标获取数据,只是打开游标而已。 要记住,Oracle 并不“回答”这个查询。打开游标时,Oracle 不复制任何数据,你可以想想看,
即使一个表有十亿条记录,是不是也能很快就打开游标?没错,游标会立即打开,它会边行进边
回答查询。换句话说,只是在你获取数据时它才从表中读数据。 在同一个会话中(或者也可以在另一个会话中;这同样能很好地工作),再从该表删除所有数据。甚
至用COMMIT 提交了删除所做的工作。记录行都没有了,但是真的没有了吗?实际上,还是可以通过游标获
取到数据。OPEN 命令返回的结果集在打开的那一刻(时间点)就已经确定。打开时,我们根本没有碰过表
中的任何数据块,但答案已经是铁板钉钉的了。获取数据之前,我们无法知道答案会是什么;不过,从游
标角度看,结果则是固定不变的。打开游标时,并非Oracle 将所有数据复制到另外某个位置;实际上是
DELETE 命令为我们把数据保留下来,把它放在一个称为undo 段(undo segment)的数据区,这个数据区
也称为回滚段(rollback segment)。

最新文章

  1. canvas贝塞尔曲线 - 2
  2. 做贴吧系统,偶然发现使用iframe的弊端
  3. JAVA 泛型与通配符的使用
  4. github中国版本coding.net 的部署和使用
  5. 经典Bug 修改方法
  6. javascript 笔记——setTimeout的参数问题
  7. Linux 用户与用户组
  8. objective -c 知識点
  9. hdoj 3549 Flow Problem(最大网络流)
  10. android-sdk-windows下载版
  11. elasticsearch学习之根据发布时间设置衰减函数
  12. Sqlautocode使用过程的一些坑
  13. Tomcat通过Memcached实现session共享的完整部署记录
  14. hdu-6415 Rikka with Nash Equilibrium dp计数题
  15. 从原型链看DOM--Node类型
  16. 广播小案例-监听系统网络状态 --Android开发
  17. Mongo 3.6.1版本Sharding集群配置
  18. ASP.NET MVC3-Music Store中英文教程 [下载]
  19. 【转】Ext JS 集合1713个icon图标的CSS文件
  20. 使用Spring Loader或者Jrebel实现java 热部署

热门文章

  1. thinkphp实现短信验证注册
  2. linux mysql命令
  3. 自定义 textField 的清除 button
  4. Android热门网络框架Volley详解
  5. 关于jsp web项目中的javax.servlet.ServletException: java.lang.NoClassDefFoundError: javax/el/ELResolver错误
  6. css考核点整理(十)-响应式开发经验,响应式页面的三种核心技术是什么
  7. Codeforces 552E - Vanya and Brackets【表达式求值】
  8. linux的grep命令
  9. Java环境的安装与配置
  10. animationWithKeyPath键值对