知识大全 oracle笔记-动态SQL

Posted 语句

篇首语:幽沉谢世事,俯默窥唐虞。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 oracle笔记-动态SQL相关的知识,希望对你有一定的参考价值。

oracle笔记-动态SQL  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

  第 章 动态SQL

   为何使用动态SQL

  实现动态SQL有两种方式 DBMS_SQL和本地动态SQL(EXECUTE IMMEIDATE)

  主要从以下方面考虑使用哪种方式

         是否知道涉及的列数和类型

  DBMS_SQL包括了一个可以 描述 结果集的存储过程(DBMS_SQL DESCRIBE_COLUMNS) 而本地动态SQL没有

         是否知道可能涉及的绑定变量数和类型

  DBMS_SQL允许过程化的绑定语句的输入 而本地动态SQL需要在编译时确定

         是否使用 数组化 操作(Array Processing)

  DBMS_SQL允许 而本地动态SQL基本不可以 但可以用其他方式实现(对查询可用FETCH BULK COLLECT INTO 对INSERT等 可用一个BEGIN … END块中加循环实现)

         是否在同一个会话中多次执行同一语句

  DBMS_SQL可以分析一次执行多次 而本地动态SQL会在每次执行时进行软分析

         是否需要用REF CURSOR返回结果集

  仅本地动态SQL可用REF CURSOR返回结果集

   如何使用动态SQL

  DBMS_SQL

         调用OPEN_CURSOR获得一个游标句柄

         调用PARSE分析语句 一个游标句柄可以用于多条不同的已分析语句 但一个时间点仅一条有效

         调用BIND_VARIABLE或BIND_ARRAY来提供语句的任何输入

         若是一个查询(SELECT语句) 调用DIFINE_COLUMN或DEFINE_ARRAY来告知Oracle如何返回结果

         调用EXECUTE执行语句

         若是一个查询 调用FETCH_ROWS来读取数据 可以使用COLUMN_VALUE从SELECT列表根据位置获得这些值

         否则 若是一个PL/SQL块或带有RETURN子句的DML语句 可以调用VARIABLE_VALUE从块中根据变量名获得OUT值

         调用CLOSE_CURSOR

  注意这里对任何异常都应该处理 以关闭游标 防止泄露资源

  本地动态SQL

  EXECUTE IMMEDIATE 语句

  [INTO 变量 变量 … 变量N | 记录体]

  [USING [IN | OUT | IN OUT] 绑定变量 … 绑定变量N]

  [RETURNING | RETURN INTO 输出 [ … 输出N]…]

  注意本地动态SQL仅支持弱类型REF CURSOR 即对于REF CURSOR 不支持BULK COLLECT

   最后说明

cha138/Article/program/Oracle/201311/18948

相关参考

知识大全 用动态SQL方法4连接 Oracle 的实现

用动态SQL方法4连接Oracle的实现  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  动态SQ

知识大全 Oracle动态SQL返回单条结果和结果集

Oracle动态SQL返回单条结果和结果集  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  DDL

知识大全 基于Oracle的高性能动态SQL程序开发

基于Oracle的高性能动态SQL程序开发  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  .静态

知识大全 PL/SQL学习笔记(一)

PL/SQL学习笔记(一)  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  基本概念 &

知识大全 PL/SQL学习笔记(五)

PL/SQL学习笔记(五)  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  创建和管理表  对象 

知识大全 SQL Server执行动态SQL正确方式

SQLServer执行动态SQL正确方式  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  SQLS

知识大全 PL/SQL开发中动态SQL的使用方法

PL/SQL开发中动态SQL的使用方法  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  内容摘要在

知识大全 动态SQL和PL/SQL的EXECUTE IMMEDIATE选项

动态SQL和PL/SQL的EXECUTEIMMEDIATE选项  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来

知识大全 动态的SQL分页

动态的SQL分页  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  alterproceduresp

知识大全 浅析PowerBuilder下动态SQL语句[1]

浅析PowerBuilder下动态SQL语句[1]  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!