易截截图软件、单文件、免安装、纯绿色、仅160KB

ORACLE中的触发器和游标是在内存中吗?

作者: 三十而立时间:2009年11月08日 12:15:21请尊重原创作品。转载请保持文章完整性,并以超链接形式注明原始作者“inthirties(三十而立)”和出处”http://blog.csdn.net/inthirties/archive/2009/11/08/4786769.aspx”,深入讨论可以联系inthirties@gmail.com。在csdn上看到一个网友问的一个问题 http://topic.csdn.net/u/20091102/20/35713B33-EACB-4A74-8735-251B9AAD156A.html ORACLE中触发器和游标执行是在内存中吗,  是不是挺耗资源,应尽量少用? 呵呵呵,这样的问题一下就把人问懵了,一时也不知道从哪里开始回答,问题倒不是很复杂,只不过笔者的问题把不同的概念杂和在一起,所以一时也不知道从哪里开始回答了。 我们来看看部分答案 实例是在内存中运行的,两者也是在内存中执行 
注意效率就好,如果需要,还是要用触发器和游标的 
游标打开并使用完后记得close 触发器和游标是两个概念。 

触发器是数据库里的一类对象,和function以及procedure一样,是一个PLSQL代码端,编译以后存在实例中,而游标是运行过程中的一个结果集的指针,trigger可以看做是内存中的静态地址,而cursor是内存中的动态部分, 这两个在这方面没有可必行。 

游标类似于数据集合的指针,性能比单个的循环query要优,但是会占用资源,所以要合理的使用。trigger是内存中的静态部分,是一个可执行的代码段,所以性能由你的实现决定。  结论先别下,我们来看看这里涉及到的理论点。 什么是触发器  什么是游标 触发器即为trigger, 是Oracle里的一种对象, 和function,sp, package,匿名的plsql段等一样,是一段PLSQL语法写的程序代码段,Oracle会编译成可执行代码,放到shared pool里,以备执行。属于内存部分里的静态部分,或者share pool不够被清空,或者改变重新编译而移出内存。 游标叻, 游标这里有两种不同的层次上的认识,一种是窄义上的,即PLSQL里都一种类型Cursor,经常在plsql里作为select批量的结果集后的存储的对象,我们可以把他看做是一个数据集合的指针,在PLSQL里通过cursor游标的操作,遍历整个批量返回的结果集,从而完成我们PLSQL里访问数据的目的, 这里可以看到,这块是动态的,不同的调用可能有不同的cursor,随之代码运行的执行完毕,这个cursor也随之而消亡,很显然这部分和具体的调用进程有关,是存在UGA里的。 游标还有一个广义上的含义,在以前解答一个有关硬解


相关文档:

Oracle 学习:PL/SQL循序渐进全面学习教程

  课程五 子查询
  
  本课重点:
  1、在条件未知的情况下采用嵌套子查询
  2、用子查询做数据处理
  3、子查询排序
  
  注意:以下实例中标点均为英文半角
  
  一、概述:
  子查询是一种SELECT句式中的高级特性,就是一个SELECT语句作为另一个语句的一个段。我们可以利用子查询来 ......

Oracle 学习:PL/SQL循序渐进全面学习教程

 课程七 其他数据库对象
  
  SEQUENCE
  
  创建实例:
  
  SQL> CREATE SEQUENCE s_dept_id
  
  2 INCREMENT BY 1
  
  3 START WITH 51
  
  4 MAXVALUE 9999999
  
  5 NOCACHE
  
  6 NOCYCLE;
  
  Sequence created.
  
  1、NEXTVAL和CURRVAL的 ......

Oracle 学习:PL/SQL循序渐进全面学习教程

 课程九 声明变量
  
  本课重点:
  1、了解基本的PLSQL块和区域
  2、描述变量在PLSQL中的重要性
  3、区别PLSQL与非PLSQL变量
  4、声明变量
  5、执行PLSQL块
  
  注意:以下实例中标点均为英文半角
  
  一、概述:
  1、PLSQL 块结构:
  DECLARE --- 可选
  变量声 ......

Oracle 学习:PL/SQL循序渐进全面学习教程

课程十一 与ORACLE SERVER交互
  
  本课重点:
  1、在PLSQL中成功的写SELECT语句
  2、动态声明PLSQL变量类型与SIZE
  3、在PLSQL中写DML语句
  4、在PLSQL中控制事务
  5、确定DML操作的结果
  
  注意:以下实例中标点均为英文半角
  
  一、PLSQL中的SQL语句:
  SELECT、DML、CO ......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号