内容摘要:在pl/sql开发过程中,使用sql,pl/sql可以实现大部份的需求,但是在某些特殊的情况下,在pl/sql中使用标准的sql语句或dml语句不能实现自己的需求,比如需要动态建表或某个不确定的操作需要动态执行。这就需要使用动态sql来实现。本文通过几个实例来详细的讲解动态sql的使用。
本文适宜读者范围:oracle初级,中级
系统环境:
os:windows 2000 professional (英文版)
oracle:8.1.7.1.0
正文:
一般的pl/sql程序设计中,在dml和事务控制的语句中可以直接使用sql,但是ddl语句及系统控制语句却不能在pl/sql中直接使用,要想实现在pl/sql中使用ddl语句及系统控制语句,可以通过使用动态sql来实现。
首先我们应该了解什么是动态sql,在oracle数据库开发pl/sql块中我们使用的sql分为:静态sql语句和动态sql语句。所谓静态sql指在pl/sql块中使用的sql语句在编译时是明确的,执行的是确定对象。而动态sql是指在pl/sql块编译时sql语句是不确定的,如根据用户输入的参数的不同而执行不同的操作。编译程序对动态语句部分不进行处理,只是在程序运行时动态地创建语句、对语句进行语法分析并执行该语句。
oracle中动态sql可以通过本地动态sql来执行,也可以通过dbms_sql包来执行。下面就这两种情况分别进行说明:
一、本地动态sql
本地动态sql是使用execute immediate语句来实现的。
1、本地动态sql执行ddl语句:
需求:根据用户输入的表名及字段名等参数动态建表。
| create or replace procedure proc_test ( table_name in varchar2, --表名 field1 in varchar2, --字段名 datatype1 in varchar2, --字段类型 field2 in varchar2, --字段名 datatype2 in varchar2 --字段类型 ) as str_sql varchar2(500); begin str_sql:=’create table ’table_name’(’field1’ ’datatype1’,’field2’ ’datatype2’)’; execute immediate str_sql; --动态执行ddl语句 exception when others then null; end ; |
Java Asp PHP .Net XML C/C++ CGI VB Jsp J2ee J2se J2me EJB Servlet Tomcat Resin Struts Weblogic Eclipse ANT GUI JMS Web servise IDEA Webphere Hibernate Spring Jboss Applet Swing Socket Javamail Perl Ajax P2P 安全 模式 框架 测试 开源 游戏
Windows XP Windows 2000 Windows 2003 Windows Me Windows 9.x Linux UNIX 注册表 操作系统 服务器 应用服务器