`

Oracle 动态SQL学习笔记

阅读更多
function open_cursor:打开一个动态游标,并返回一个整型;

procedure close_cursor(c in out integer);关闭一个动态游标,参数为open_cursor所打开的游标;

procedure parse(c in integer, statement in varchar2, language_flag in integer):对动态游标所提供的sql语句进行解析,参数C表示游标,statement为sql语句,language-flag为解析sql语句所用oracle版本,一般有V6,V7跟native(在不明白所连database版本时,使用native);

procedure define_column(c in integer, position in integer, column any datatype, [column_size in integer]):定义动态游标所能得到的对应值,其中c为动态游标,positon为对应动态sql中的位置(从1开始),column为该值所对应的变量,可以为任何类型,column_size只有在column为定义长度的类型中使用如VARCHAR2,CHAR等(该过程有很多种情况,此处只对一般使用到的类型进行表述);

function execute(c in integer):执行游标,并返回处理一个整型,代表处理结果(对insert,delete,update才有意义,而对select语句而言可以忽略);

function fetch_rows(c in integer):对游标进行循环取数据,并返回一个整数,为0时表示已经取到游标末端;

procedure column_value(c in integer, position in integer, value):将所取得的游标数据赋值到相应的变量,c为游标,position为位置,value则为对应的变量;

procedure bind_variable(c in integer, name in varchar2, value):定义动态sql语句(DML)中所对应字段的值,c为游标,name为字段名称,value为字段的值;

以上是在程序中经常使用到的几个函数及过程,其他函数及过程请参照oracle所提供定义语句dbmssql.sql

(二)一般过程
对于一般的select操作,如果使用动态的sql语句则需要进行以下几个步骤:
open cursor--->parse--->define column--->excute--->fetch rows--->close cursor;
而对于dml操作(insert,update)则需要进行以下几个步骤:
open cursor--->parse--->bind variable--->execute--->close cursor;
对于delete操作只需要进行以下几个步骤:
open cursor--->parse--->execute--->close cursor;


实例分析
create or replace procedure p_oneproduc is
--变量定义
iid int;
icount int;
strtblname varchar2(
100);
ssql varchar2(
1024);
serrmsg varchar2(
1024);
cid1 number;--动态游标光标编号
cid2 number;--动态光标编号
iipno number;--从动态光标中取出值的存放变量
idateno number;--从动态光标中取出值的存放变量
i number;
cursor cur1 is select id,table_name from userisit where status=
2;--定义一个光标
--定义结束
begin
 select count(*) into icount from uservisit where status=
2;//查询用户访问表将记录汇总统计存入icount中
 if icount>
0 then   
    open cur1;//打开cur1光标
      fetch cur1 into iid,strtblname; //取出光标的值并赋值给iid,strtblname,相应的变量和select变量同序
      exit when cur1%notfound; //如果记录为空时退出 cur%notfound是cur的一个变量,当记录为空时为true
      
--重头戏,,动态SQL开始(具体可以参考前面的方法说明)
      ssql:='select distinct ipno,dateno from '||strtblname; --定义一个SQL语句,后面用动态SQL进行执行
      cid1:=dbms_sql.open_cursor; --定义一个动态光标用来执行前面定义的SQL语句
      dbms_sql.Parse(cid1,ssql,dbms_sql.v7); --分析SQL语句
      dbms_sql.Define_Column(cid1,
1,iipno); --定义要取出的字段值,1表示第一个字段要取出,即Select语句的ipno
      dbms_sql.Define_Column(cid1,
2,idateno);--同上说明
      icount:=dbms_sql.execute(cid1); --执行Sql语句,这里icount得到一个执行的结果
      --执行SQL语句可以和普通光标一样进行取值操作
      i:=0;
      loop
        If dbms_sql.fetch_rows(cid1) >
0 then --如果动态光标的记录数大于0,则进行取值操作
          begin
            dbms_sql.column_value(cid1,
1,iipno); --取出值
            dbms_sql.column_value(cid1,
2,idateno);--同上
           
            select count(*) into icount from pmhtmpunchkcpc@unionbill where ipno=iipno and dateno=idateno;
            if icount>
0 then
              ssql:=
'update FIRSTCDAY_'||idateno||'@unionbill set isreach=1 where ipno='
||iipno;
              execute immediate ssql;//动态立即执行一个SQL语句
            end if
           end
        end if
      end loop
        
exception when others then
           null;
        end;
   --运用动态光标执行一组插入操作 (纯碎是为了记录动态插入中的赋值的用法,无逻辑可言)
     ssql:= 'insert uservisit(ipno,dateno) values(:iipno,:idateno)'; --定义一个SQL语句,后面用动态SQL进行执行
     cid2:=dbms_sql.open_cursor; --定义一个动态光标用来执行前面定义的SQL语句
     dbms_sql.Parse(cid2,ssql,v7);
     for j in 1..999 loop
      dbms_sql.bind_variable(cid2, 'ipno', j);
      dbms_sql.bind_variable(cid2, 'dateno', 2);
      icount := dbms_sql.execute(cursor2);--插入数据
    end loop;

    
     
  

     --关闭光标的不要忘记了
     if(dbms_sql.is_open(cid1)) then --如果动态光标仍然是开的
        dbms_sql.close_cursor(cid1); --关闭
     end if;
     ---记得关掉第二个动态光标
     if cur1%isopen then
        close cur1;
     end if;













分享到:
评论

相关推荐

    oracle 数据库 SQL学习笔记

    Oracle数据库是全球广泛使用的...总的来说,Oracle数据库SQL学习笔记应该涵盖这些核心领域,并深入探讨每个主题,包括实例、最佳实践和问题解决策略。通过持续学习和实践,你可以成为一名熟练的Oracle数据库专业人员。

    精通 ORACLE SQL高级编程 学习笔记

    精通Oracle SQL【第2版】ORACLE SQL高级编程【第二版】学习笔记

    Oracle 10g sql 学习笔记

    Oracle 10g SQL 学习笔记涵盖了Oracle数据库的基础知识,包括版本信息、数据库系统特点、关系型数据库结构、SQL语言、操作环境以及常见的数据库操作。以下是对这些知识点的详细说明: 1. **Oracle 9i基础知识**: ...

    Oracle SQLServer数据库 学习笔记

    这篇学习笔记将深入探讨这两个系统的概念、特性和应用。 一、Oracle数据库系统 Oracle数据库是由甲骨文公司开发的一款强大、高性能的数据库解决方案。其主要特点包括: 1. **分布式数据库**:Oracle支持多节点的...

    Mastering_Oracle_SQL学习笔记

    在深入探讨《Mastering Oracle SQL学习笔记》的内容之前,我们先理解一下这门课程的核心目标:帮助初学者更好地掌握SQL语言中的关键概念和操作,尤其是针对Oracle数据库的特性。这包括了SQL语句的构建、数据筛选、...

    Oracle_SQL学习笔记

    ### Oracle SQL 学习笔记关键知识点详解 #### 一、SQL 并行查询 并行查询是 Oracle 提供的一种提高查询性能的技术,特别是在处理大型数据集时尤其有效。通过利用多处理器或多核 CPU 的能力,并行查询能够显著加快...

    成功之路:Oracle11g学习笔记.pdf

    在介绍Oracle系统管理的知识以后,将介绍与开发相关的内容(如PL/SQL基础知识、存储过程、函数、包等),并介绍数据库性能调整,《成功之路:Oracle 11g学习笔记》重点介绍SQL语句调优。SQL语句调优是《成功之路:Oracle...

    oracle_sql笔记

    Oracle SQL是数据库管理员和开发人员在Oracle数据库系统中进行数据查询和管理的重要工具。这篇笔记主要涵盖了Oracle SQL的...这两份“Oracle SQL笔记”文档应包含了上述各个方面的详细解释和实例,值得仔细阅读和学习。

    Oracle_SQL学习笔记.doc

    这些是Oracle SQL学习中的一些基础和进阶知识点,它们对于高效地管理Oracle数据库至关重要。理解并熟练掌握这些概念,可以帮助你编写更高效、更稳定的SQL语句,优化数据库性能,并确保数据的一致性和完整性。

    ORACLE_SQL学习笔记

    在学习Oracle SQL时,我们需要掌握各种关键概念和语法,以便高效地进行数据查询、更新和管理。以下是一些核心知识点: 1. **并行查询**:并行查询是提高大数据处理效率的一种策略。通过`ALTER SESSION ENABLE ...

    java+SSH+oracle+sqlserver学习笔记

    【Java SSH Oracle SQLServer 学习笔记】 Java是一种广泛使用的面向对象的编程语言,它以其跨平台、开源和丰富的库而闻名。SSH是三个开源框架的缩写,分别是Spring、Struts和Hibernate,它们在Java Web开发中起着至...

    成功之路Oracle11g学习笔记

    其次,SQL是与Oracle交互的主要工具,学习笔记会详细介绍SQL的语法和用法。SQL语言分为DDL(Data Definition Language)、DML(Data Manipulation Language)、DCL(Data Control Language)和TCL(Transaction ...

    Oracle_SQL学习笔记[参照].pdf

    以下是一些关于Oracle SQL学习笔记中的关键知识点: 1. **并行查询**:Oracle SQL支持并行查询以提高性能,通过`ALTER SESSION ENABLE PARALLEL DML`开启并行DML操作。`SELECT`语句中的`/*+PARALLEL(a, N)*/`提示...

    SQL学习笔记(pdf)

    这份"SQL学习笔记"涵盖了SQL的基础概念、语法以及高级特性,是学习数据库管理和数据分析的宝贵资料。 1. **SQL基础** - 数据库概念:了解什么是数据库,它的作用以及数据库管理系统(DBMS)如何工作。 - SQL简介...

    Oracle学习笔记 PDF

    ### Oracle学习笔记知识点详解 #### 一、Oracle简介 Oracle是一家知名的软件公司,以其数据库管理系统闻名全球。该公司成立于1977年,总部位于美国加利福尼亚州。Oracle不仅提供数据库解决方案,还涉及中间件、...

    Oracle 10g 学习笔记

    │ Oracle学习笔记.pdf │ Oracle学习笔记.wps │ 安装Oracle后myEclipse不能正常使用.txt │ 手工配置listener.ora【避免出现ORA-12514错误】.txt │ 贴子树状态存储结构.jpg │ 贴子树状态存储结构.sql │ ├─01...

Global site tag (gtag.js) - Google Analytics