对于一般的(select)操作,如果使用动态的sql语句则需要进行以下几个步骤:
open  cursor--->parse---> bind  variable  ---> define  column(单条)/define_array(多条) --->excute---> fetch  rows---> variable_value ---> close  cursor;

对于dml操作(insert,update)则需要进行以下几个步骤:
open  cursor--->parse---> bind  variable--->execute---> variable_value---> close  cursor;

对于(delete)操作只需要进行以下几个步骤:
open  cursor--->parse---> bind  variable---> execute--->variable_value--->  close  cursor;

例:

create table cux_demo (a number,b number,c number); begin   for i in 1 .. 15 loop     insert into cux_demo     values       (round(dbms_random.value, 2) * 100,        round(dbms_random.value, 2) * 100,        round(dbms_random.value, 2) * 100);   end loop;   commit; end;

1. 执行一般的 select 语句返回某一条记录(一次返回一条记录)。 DECLARE  cursor_name  INTEGER ;  v_sql        VARCHAR(200);  p_no1        NUMBER := 80;  p_no2        NUMBER := 80;    v_b1         NUMBER;  v_b2         NUMBER;  v_b3         NUMBER;    row_process INTEGER;BEGIN

  v_sql :='select * from cux_demo where a= :ano and b=:bno';  --查询sql语句      cursor_name:= dbms_sql.open_cursor;    --打开游标;      dbms_sql.parse(cursor_name,v_sql,dbms_sql.native);   --解析动态SQL语句;    dbms_sql.bind_variable(cursor_name,'ano', p_no1);     --绑定输入参数;  dbms_sql.bind_variable(cursor_name,'bno', p_no2);     --绑定输入参数;  

  dbms_sql.define_column(cursor_name,1,v_b1);  --定义返回列;第二个参数是指需要返回的字段在查询结果中处于第几列,第三个参数就是接收返回结果需要的变量。  dbms_sql.define_column(cursor_name,2,v_b2);      dbms_sql.define_column(cursor_name,3,v_b3);       row_process := dbms_sql.execute(cursor_name);  --执行动态SQL语句   LOOP    IF dbms_sql.fetch_rows(cursor_name) > 0 THEN         dbms_sql.column_value(cursor_name,1, v_b1);         dbms_sql.column_value(cursor_name,2, v_b2);      dbms_sql.column_value(cursor_name,3, v_b3);                  dbms_output.put_line(v_b1 || ';' || v_b2 || ';' || v_b3);    ELSE      EXIT;    END IF;  END LOOP;

  dbms_sql.close_cursor(cursor_name);

EXCEPTION  WHEN OTHERS THEN    dbms_sql.close_cursor(cursor_name);END;

2. 使用 define_array 方法一次得到多行查询结果。DECLARE  cursor_name     INTEGER ;  v_sql              VARCHAR(200);  n_tab1             dbms_sql.number_table;  n_tab2             dbms_sql.number_table;    indx               NUMBER := 1;        row_process     INTEGER;

BEGIN

   v_sql :='select * from cux_demo where rownum<13 order by 1';  --查询sql语句       cursor_name:= dbms_sql.open_cursor;    --打开游标;       dbms_sql.parse(cursor_name,v_sql,dbms_sql.native);   --解析动态SQL语句;

   介绍一下define_array函数的   --第一个参数是已经打开的cursor名称,    --第二个参数是指需要返回的字段在查询结果中处于第几列;   --第三个参数就是接收返回结果需要的变量,与define_column不同的是此变量是table,而不是普通的字段类型;   --第四个参数表示一次可以返回的行数;  --第五个参数是指n_tab的index从哪个数值开始,此数值是递增的.在此例中index是从1开始的,一次得到9行结果集。  dbms_sql.define_array(c,1,n_tab1,9,indx);    dbms_sql.define_array(c,2,n_tab2,9,indx);      row_process := dbms_sql.execute(cursor_name);  --执行动态SQL语句  LOOP    row_process := dbms_sql.fetch_rows(cursor_name);    dbms_output.put_line('fetch rows is ' || row_process);   EXIT WHEN row_process < 9;        dbms_sql.column_value(cursor_name, 1, n_tab1);    dbms_sql.column_value(cursor_name, 2, n_tab2);          FOR i IN 1 .. row_process LOOP      dbms_output.put_line(n_tab(i) || ',' || n_tab1(i));    END LOOP;

  END LOOP;

  dbms_sql.close_cursor(cursor_name);EXCEPTION  WHEN OTHERS THEN    dbms_sql.close_cursor(cursor_name);END;

Oracle之DBMS_SQL包用法详解的更多相关文章

  1. Oracle之UTL_FILE 包用法详解

    [转自] http://zhangzhongjie.iteye.com/blog/1903024 UTL_FILE包可以用来读写操作系统上的文本文件,UTL_FILE提供了在客户端(FORM等等)和服 ...

  2. Oracle之DBMS_LOCK包用法详解

    概述与背景 某些并发程序,在高并发的情况下,必须控制好并发请求的运行时间和次序,来保证处理数据的正确性和完整性.对于并发请求的并发控制,EBS系统可以通过Concurrent Program定义界面的 ...

  3. oracle正则表达式regexp_like的用法详解

    oracle正则表达式regexp_like的用法详解 /*ORACLE中的支持正则表达式的函数主要有下面四个:1,REGEXP_LIKE :与LIKE的功能相似2,REGEXP_INSTR :与IN ...

  4. golang格式化输出-fmt包用法详解

    golang格式化输出-fmt包用法详解 注意:我在这里给出golang查询关于包的使用的地址:https://godoc.org    声明: 此片文章并非原创,大多数内容都是来自:https:// ...

  5. Spring3.0.5jar包用法详解 [转载]

    Spring3.X以后jar包进行了重构,取消了原来2.X版本中的总的spring.jar包,而是把总包中的功能全部分开打包.正在向osgi靠拢. 各个jar包详解如下: 1. org.springf ...

  6. java多线程管理 concurrent包用法详解

        我们都知道,在JDK1.5之前,Java中要进行业务并发时,通常需要有程序员独立完成代码实现,当然也有一些开源的框架提供了这些功能,但是这些依然没有JDK自带的功能使用起来方便.而当针对高质量 ...

  7. oracle add_months函数的用法详解

    如果需要取上一个月的数据,并且每天都要进行此操作,每次都需要改时间,的确非常的麻烦,所以想到了oracle add_months函数这个函数 oracle add_months函数: oracle a ...

  8. Oracle DECODE函数的用法详解

    Oracle DECODE函数使用方法: 1.比较大小select decode(sign(变量1-变量2),-1,变量1,变量2) from dual; --取较小值sign()函数根据某个值是0. ...

  9. Oracle Merge Into的用法详解

    1.    MERGE INTO 的用途         MERGE INTO 是Oracle 9i以后才出现的新的功能.那这个功能 是什么呢?         简单来说,就是:“有则更新,无则插入” ...

随机推荐

  1. linux--svn checkout

    svn --username=yourname co svn_path local_path

  2. Respond.js的作用

    在html页面中我们经常看到 <!--[if lt IE 9]>    //判断当前浏览器的版本是否小于IE 9          <script src="https:/ ...

  3. spring:使用会话和请求作用域

    在Web应用中,如果能够实例化在会话和请求范围内共享的bean,那将是非常有价值的事情.例如,在典型的电子商务应用中,可能会有一个bean代表用户的购物车.如果购物车是单例的话,那么将会导致所有的用户 ...

  4. WebView的简单使用

    activity_main.xml: <?xml version="1.0" encoding="utf-8"?> <LinearLayout ...

  5. JVM和Dalvik VM的简要区别

    一.结构 JVM是栈堆   Dalvik VM是寄存器 二.编译 JVM:.java>.class>.jar Dalvik VM:.java>.class>.dex>.o ...

  6. LeetCode OJ:Contains Duplicate(是否包含重复)

    Given an array of integers, find if the array contains any duplicates. Your function should return t ...

  7. cmake安装MySQL数据库实例

    一.编译安装MySQL前的准备工作 首先检查是否有安装其他版本的编译器和数据库,先卸载干净. 安装编译源码所需的工具和库 yum install gcc gcc-c++ ncurses-devel p ...

  8. 线程存储(Thread Specific Data)

    线程中特有的线程存储, Thread Specific Data .线程存储有什么用了?他是什么意思了? 大家都知道,在多线程程序中,所有线程共享程序中的变量.现在有一全局变量,所有线程都可以使用它, ...

  9. NOIP模拟题 斐波那契数列

    题目大意 给定长度为$n$序列$A$,将它划分成尽可能少的若干部分,使得任意部分内两两之和均不为斐波那契数列中的某一项. 题解 不难发现$2\times 10^9$之内的斐波那契数不超过$50$个 先 ...

  10. C++对C语言的拓展(5)—— 函数重载和函数指针结合

    1.函数指针的介绍 函数指针指向某种特定类型,函数的类型由其参数及返回类型共同决定,与函数名无关.举例如下: int add(int nLeft,int nRight);//函数定义 该函数类型为in ...