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表空间操作详解
1
2
3作者: 来源: 更新日期:2006-01-04
5
6
7建立表空间
8
9CREATE TABLESPACE data01
10DATAFILE '/ora ......
oracle 存储过程的基本语法 及注意事项
oracle 存储过程的基本语法
1.基本结构
CREATE OR REPLACE PROCEDURE 存储过程名字
(
参数1 IN NUMBER,
参数2 IN NUMBER
) IS
变量1 INTEGER :=0;
变量2 DATE;
BEGIN
END 存储过程名字
2.SELECT INTO STATEMENT
将selec ......
课程六 运行时应用变量
本课重点:
1、创建一个SELECT语句,提示USER在运行时先对变量赋值。
2、自动定义一系列变量,在SELECT运行时进行提取。
3、在SQL PLUS中用ACCEPT定义变量
注意:以下实例中标点均为英文半角
一、概述:
变量可 ......
课程九 声明变量
本课重点:
1、了解基本的PLSQL块和区域
2、描述变量在PLSQL中的重要性
3、区别PLSQL与非PLSQL变量
4、声明变量
5、执行PLSQL块
注意:以下实例中标点均为英文半角
一、概述:
1、PLSQL 块结构:
DECLARE --- 可选
变量声 ......
使用java + oracle插入clob类型的数据,需要用以下的步骤:
1、将数据插入数据库,对于clob字段,使其为空clob数据。例如:insert into test values(1,empty_clob())";
2、从数据库中取出插入的clob字段,并将其赋值给oracle.sql.clob类型的变量。例如
String sqll="select content from test where id=1 for upda ......