Oracle执行SQL语句就是打开游标,解析游标,执行游标,关闭游标的过程。了解游标的这几个阶段,我们也就弄清楚了SQL执行过程,这是本文要介绍的第一个内容。另外,在java编程中,我们通常说要使用预处理的形式来写SQL语句(比如:select * from table where A = ?),也就是绑定变量的形式。因为,这样效率高。那么,为什么使用绑定变量就比不使用绑定变量(比如:select * from table where A = "123")要效率高呢?这是本文要介绍的第二个内容。一. 游标的生命周期一条sql语句的执行过程,就是一个游标的生命周期。如下图所示:1. 打开游标:系统为这个游标分配一个内存结构。2. 解析游标:将一条SQL与这个游标关联。解析这条sql语句,将解析的结果加载到共享池中。3. 定义输出变量:如果这条SQL返回数据,先定义接收数据的变量。4. 定义输入变量:如果SQL语句使用了绑定变量,提供他们的值。5. 执行游标:执行SQL语句。6. 获取游标:如果SQL语句有返回数据,接收返回的数据。7. 关闭游标:释放第一步分配的内存,供其他游标使用,但是第二步解析的SQL结果(也就是共享游标)不会被释放,以期待被重新使用。我们可以通过一段PL/SQL代码来看一下游标的这几个步骤: DECLARE
l_ename emp.ename%TYPE := "SCOTT";
l_empno emp.empno%TYPE;
l_cursor INTEGER;
l_retval INTEGER;
BEGIN
l_cursor := dbms_sql.open_cursor; /*打开游标*/
dbms_sql.parse(l_cursor, "SELECT empno FROM emp WHERE ename = :ename", 1); /*解析游标*/
dbms_sql.define_column(l_cursor, 1, l_empno); /*定义输出变量*/
dbms_sql.bind_variable(l_cursor, ":ename", l_ename); /*定义输入变量*/
l_retval := dbms_sql.execute(l_cursor); /*执行游标*/
IF dbms_sql.fetch_rows(l_cursor) > 0 /*获取游标*/
THEN
dbms_sql.column_value(l_cursor, 1, l_empno);
dbms_output.put_line(l_empno);
END IF;
dbms_sql.close_cursor(l_cursor); /*关闭游标*/
END;
Oracle number类型的语法和用法Oracle 对象统计信息相关资讯 Oracle游标 Oracle绑定变量
- Oracle游标的使用方法 (今 13:57)
- Oracle游标—for、loop、if结合应 (05/01/2015 17:43:10)
- Oracle游标介绍 (02/09/2015 10:32:04)
| - Oracle优化实战(绑定变量) (06/16/2015 20:01:38)
- Oracle 游标使用全解 (05/01/2015 17:35:19)
- Oracle使用游标为所有用户表创建主 (02/08/2015 11:22:49)
|
本文评论 查看全部评论 (0)