当前位置: 首页 > 图文教程 > 数据库 > Oracle > 基于Oracle高性能动态SQL程序开发

Oracle
教你应对Oracle检索数据的一致性以及回滚数据
美国家庭影院频道成功实施Oracle套件
Oracle学习教程
利用oracle外部表查看报警信息
合理设置临时表空间确保Oracle数据库正常运行
Oracle数据库如何处理临时数据?
ORACLE报警日志如何查看?
Oracle教程:如误添加数据文件如何删
Oracle10gR2上遇到了Mutex竞争的问题
Oracle教程:讲述表与表见得连接
Oracle教程:修改初始化参数
Oracle教程:工具kfod的使用
Oracle数据库是如何进制转换的
两种方法来组织Oracle数据库中的数据
Oracle教程:如何将数据文件移到新区
三要素助你在Oracle中创建索引
如何将各种数据库连接起来?
Oracle数据库导入外部数据如何实现
Oracle数据库的输出方法调试
Oracle教程:数据的复制

基于Oracle高性能动态SQL程序开发


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-30   浏览: 123 ::
收藏到网摘: n/a

1.静态SQLSQL与动态SQL

注释:本文主要就动态SQL的开发进行讨论,并在最后给出一些实际开发的技巧。

2. 动态SQL程序开发:

 

 

Excute immediate 动态SQL语句 using 绑定参数列表 returning into 输出参数列表;

对这一语句作如下说明:

(1) 动态SQL是指DDL和不确定的DML(即带参数的DML)。

(2) 绑定参数列表为输入参数列表,即其类型为in类型,在运行时刻与动态SQL语句中的参数(实际上占位符,可以理解为函数里面的形式参数)进行绑定。

(3) 输出参数列表为动态SQL语句执行后返回的参数列表。

(4) 由于动态SQL是在运行时刻进行确定的,所以相对于静态而言,其更多的会损失一些系统性能来换取其灵活性。

为了更好的说明其开发的过程,下面列举一个实例:

设数据库的ep表,其数据为如下:

ID NAME SALARY
100 Jacky 5600
101 Rose 3000
102 John 4500

要求:

1.创建该表并输入相应的数据。

2.根据特定ID可以查询到其姓名和薪水的信息。

3.根据大于特定的薪水的查询相应的员工信息。

根据前面的要求,可以分别创建三个过程(均使用动态SQL)来实现:

过程一:

create or replace procedure create_table
asbeginexecute immediate 'create table emp
(id number,name varchar2(10)salary number; )';
--动态SQL为DDL语句
insert into empvalues (100,'jacky',5600);
insert into empvalues (101,'rose',3000);
insert into empvalues (102,'john',4500);end create_table;

过程二:

create or replace procedure find_info(p_id number)
asv_name varchar2(10);v_salary number;beginexecute
immediate 'select name,salary from empwhere id=:1'
using p_idreturning into v_name,v_salary;
--动态SQL为查询语句dbms_output.put_line
(v_name ||'的收入为:'||to_char(v_salary));
exceptionwhen others thendbms_output.put_line('找不到相应数据');
end find_info;

过程三:

create or replace procedure find_emp(p_salary number)
asr_emp emp%rowtype;type c_type is ref cursor;c1 c_type;
beginopen c1 for 'select * from empwhere salary >:1'
using p_salary;loopfetch c1 into r_emp;exit when
c1%notfound;dbms_output.put_line
('薪水大于‘||to_char(p_salary)||’的员工为:‘);
dbms_output.put_line('ID为'to_char(r_emp)||'
其姓名为:'||r_emp.name);end loop;close c1;end create_table;