如果你用的是 Oracle 8i 及以上的版本,那简单,在过程中用 execute immediate sql_str 就行, sql_str 是一个拼凑的 SQL 语句,

如果你用的是 Oracle 8i 及以上的版本,那简单,在过程中用 execute immediate sql_str 就行, sql_str 是一个拼凑的 SQL 语句,但这个动态语句中带参数,或 Select 的结果要 into 到变量中时就要稍加留心一下了。而在 8i 以前的版本(谁还用这么古老的玩艺,总有些不得已的地方,老系统考虑升级成本遗留下来的,应用软件所伴随着的等),都没法用 execute immediate,,就得使用 DBMS_SQL 包来实现了

何谓动态 SQL 和 DDL 语句呢?通常在过程中要操作的表名、字段名都必须是明确的,否则编译过程时就要报错,但如果这两者也用变量名来表示就是动态的。DDL 就是数据库对象定义的操作,如 CREATE TABLE/VIEW/INDEX/SYN/CLUSTER……,及这些对象的删除、修改操作等等。

比如在 Oracle 中有执行下面过程块的意图时,就要使用到 execute immediate 或是 DBMS_SQL 包了。当然下面的语句块是通不过的。

declare

col_name varchar2(30) := 'name'; --假定表user存在name字段

col_val varchar2(30);

begin

select col_name into col_val --按照惯常思维,可能就会这么写

from user where age between 18 and 25; --编译时会提示列名不存在的

drop table t2; --不能直接执行 DDL 语句,后面查询 t2 编译器就无能为力了

end;

现在我们提出对上面问题的解,针对第一个 Select 语句来说明,并假设查询中还带有参数。块中的 DDL 也是类似的解法。例子因力图涵盖更多内容,所以稍显复杂,如果不需要 into (如 update/delete 语句),或者不带参数,会简单多了,应不难简化。有两种处理方法,以 8i 为分水岭。

1. Oracle 8i 及以上版本的过程中处理动态 SQL 语句的办法

declare

v_col_name varchar2(30) := 'name'; --字段名 name 用变量来表示

v_user_name varchar2(30); --用户名称

v_user_age integer; --用户年龄

v_sql_str varchar2(500); --动态 SQL 语句

begin

v_sql_str := 'select '||v_col_name||',age from users --字段名后面不能紧随 into 到变量了

where age between :start_age and :end_age and rownum=1'; --两个命名参数

--用 execute immediate 动态执行 SQL 语句

--注意其后的 into 字段值到变量的写法,还有 using 来代入参数

execute immediate v_sql_str into v_user_name,v_user_age using 18,25;

dbms_output.put_line('第一个符合条件的用户:'||v_user_name||',年龄:'||v_user_age);

end;

除此之外,在 Oracle 8i 及以上版本中,还能用 DBMS_UTILITY.EXEC_DDL_STATEMENT(ddl_sql_str) 执行 DDL 语句。

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:php中文网

oracle 动态执行ddl语句,Oracle过程中执行动态SQL或DDL语句相关推荐

  1. Android启动过程中执行一个C语言的应用程序或者执行shell脚本

    Android启动过程中执行一个C语言的应用程序或者执行shell脚本 一.Android启动过程中去对系统做一些设置,如修改某些文件夹的属性和文件的权限,可在init.rc中增加service执行s ...

  2. python的for语句条件_Python中的条件选择和循环语句

    Python中的条件选择和循环语句 同C语言.Java一样,Python中也存在条件选择和循环语句,其风格和C语言.java的很类似,但是在写法和用法上还是有一些区别.今天就让我们一起来了解一下. 一 ...

  3. 如何在本机执行 pyscript (在网页中执行python)

    如何在本机执行 pyscript (在网页中执行python) pyscript可以让使用者在 H5 的网页中执行 python 的语法,目前只是alpha版本,如果透过官方网站执行,速度会很慢,还有 ...

  4. oracle嵌套三层循环语句,在存储过程中执行3种oracle循环语句

    http://www.cnblogs.com/coprince/p/3443219.html create or replace procedure pr_zhaozhenlong_loop /* 名 ...

  5. ORACLE RAC TO RAC DG搭建过程中可能遇到的问题

    在ORACLE DataGuard部署过程中,如果操作不规范,可能遇到很多想不到的问题.有些问题是配置参数不到位,有些 是操作不规范遗漏导致. 问题一     主库复制备库到备机时,rman远程登陆主 ...

  6. oracle错误oui 25031,搭建Oracle10gRAC过程中出现OUI-25031的解决办法

    OS 版本是:Enterprise Linux Enterprise Linux Server release 5.4DB 版本是:Oracle Database 10g Enterprise Edi ...

  7. ef执行原生sql语句_EF Core中执行原生SQL语句

    一.课程介绍之所以今天录制这个系列文章的主要原因是,想在快速帮助到大家上手在ASP.NET Core WebAPI中结合EF Core来操作我们的数据库.EF Core的基础文章和基础课程实在是太多了 ...

  8. 菌群在发酵过程中如何动态演替

    近期,派森诺与华中农业大学合作,再次在美国微生物协会(ASM)旗下的<Microbiology Spectrum>发表文章,通过扩增子测序和代谢组检测等手段,对两阶段固态发酵系统中微生物群 ...

  9. RabbitMQ安装过程中执行rabbitmq-plugins enable rabbitmq_management遇到Plugin configuration unchanged问题

    使用管理员权限打开命令控制符 进入到RabbitMQ的安装目录sbin下 执行rabbitmq-service.bat remove命令 再执行set RABBITMQ_BASE=E:\rabbitM ...

最新文章

  1. 1105 Spiral Matrix 给定数组向螺旋矩阵中填入数据
  2. lattice LFE3-17EA 调试记录
  3. Linux扫盲篇:CentOS、Ubuntu、Gento
  4. 二、应用层协议概述与HTTP
  5. python是一种什么编程语言-想自学一种编程语言,各种编程语言都有什么区别?...
  6. c# 说说开发通用通信库,尤其是分布式服务的通信
  7. SQL内连接和左连接的区别 - 使用SQLite演示
  8. 独立成分分析 ( ICA ) 与主成分分析 ( PCA ) 的区别
  9. Clipboard.js实现点击自动复制内容的功能
  10. matlab电机标定,基于模型的电机标定及高精度电机建模
  11. linux用户管理和群界面怎么打开,Linux命令行界面下的用户和组的管理
  12. 《网络基础》- 第3集-IP地址、子网掩码和路由器的作用
  13. 内核aio_IO模型_NIO_AIO
  14. 计算机世界:免费的代价
  15. 接口与抽象类的相同点和不同点
  16. 国际项目投标那些事(六)投标文件怎么写才能惊呆业主 WTSolutions
  17. ios设备管理 iMazing官方免费激活电脑版下载v2.11.6.0
  18. vue-element-admin 后台管理系统
  19. Elasticsearch+cerebro部署文档
  20. Sicily 1048. Inverso

热门文章

  1. EBS总账(GL)模块常用表
  2. 【线性代数】向量组的线性相关性
  3. 百度惊现区块链项目“莱茨狗”,俄罗斯财长称不会允许自由地交易数字货币 | 区块链日报
  4. android 9 vxp 闪退,小米9无法启动,打开就闪退
  5. ubunto、 配置mysql
  6. 利用安卓SQLite修改QQ运动步数方法分享 简单粗暴
  7. 瑞吉外卖项目——新增套餐
  8. 城市天际线 android,城市天际线手机安卓版
  9. JPG免费转PDF的方法分享
  10. 远程连接服务器频繁掉线,远程桌面一连就断的解决方法(经常掉线)