对于一般的(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. spring boot: 线程池ThreadPoolTaskExecutor, 多线程

    由于项目里需要用到线程池来提高处理速度,记录一下spring的taskExecutor执行器来实现线程池. ThreadPoolTaskExecutor的配置在网上找了很多解释没找到,看了下Threa ...

  2. IDT 查询 hana SQL 聚合问题。

    因为业务需要,用HANA的数据做成DASHBOARD.工厂运营概况.结果发现奇怪的问题.明明是一个类型的但是不会聚合.(数据量特别大,一个月的应该就一条,但是有几千条做不下去.) 比如车辆类型是 焊装 ...

  3. Linux_总结_01_VMware14虚拟机下安装CentOS7.x

    一.前言 本文是采用最小安装方式 二.下载 1.官网 https://www.centos.org/download/ 在此页面下,选择 Minimal ISO 进行下载. 三.VMWare中新建虚拟 ...

  4. Codeforces Round #254(div2)A

    很有趣的题.想到了就非常简单,想不到就麻烦了. 其实就是一种逆向思维:最后结果肯定是这样子: WBWBWBWB... BWBWBWBW... WBWBWBWB... ... 里面有“-”的地方改成“- ...

  5. rpy2的安装问题?【解决】

    https://www.zhihu.com/question/46555829 http://blog.sciencenet.cn/blog-365459-901335.html

  6. HAWQ 官方文档创建filespace,tablespace,database,table

    1.创建Filespace 创建Filespace必须是数据库超级用户( You must be a database superuser to create a filespace.)首先创建一个f ...

  7. java-03方法课堂练习

    1.java中利用static(静态),将方法放入类中.如果不加static,必须先实例化出来一个类,之后再通过实例化类名+方法的形式调用. 2.编写一个方法,使用以上算法生成指定数目(比如1000个 ...

  8. Node中没搞明白require和import,你会被坑的很惨

    ES6标准发布后,module成为标准,标准的使用是以export指令导出接口,以import引入模块,但是在我们一贯的node模块中,我们采用的是CommonJS规范,使用require引入模块,使 ...

  9. C#获取堆栈信息,输出文件名、行号、函数名、列号等

    命名空间:System.Diagnostics 得到相关信息: StackTrace st = new StackTrace(new StackFrame(true));StackFrame sf = ...

  10. What makes an inferred latch? how To avoid creating inferred latches? when do you know you need latches?

    What makes an inferred latch?For combinatorial logic, the output of the circuit is a function of inp ...