• DBMS_SQL包的使用


    在PL/SQL程序设计过程中,必然会遇到动态SQL,我们可以使用DMBS_SQL包来完成。下面对DMBS_SQL系统包的常用函数进行简要说明。
    (1) function open_cursor:打开一个动态游标,并返回一个整型。

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

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

    (4) 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等(该过程有很多种情况,此处只对一般使用到的类型进行表述)。

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

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

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

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

    (9) function is_open(c in integer):判断游标是否处于打开状态。 


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

  • 相关阅读:
    sql server 2008收缩数据库日志
    小题大做之MySQL 5.0存储过程编程入门(收藏)
    精进不休 .NET 4.0 (5) C# 4.0 新特性之并行运算(Parallel) (收藏)
    GridView 格式化<收藏>
    MySql捕获sql语句异常的方法
    Windows7发生VS2005无法调试Web项目
    mysql 5.0存储过程学习总结《转载》
    HashMap和Hashtable及HashSet的区别
    iphone 界面实现下拉列表
    Java中堆和栈的区别
  • 原文地址:https://www.cnblogs.com/prettymdx/p/2072017.html
Copyright © 2020-2023  润新知