首页 | 资讯动态 | linux基础 | 系统管理 | 网络管理 | 编程开发 | linux数据库 | 服务器技术 | linux相关 | linux认证 | 嵌入式 | 下载中心 | 专题 | linux招聘 | HR | 镜像
OKLinux中文技术站
·设为首页
·加入收藏
·联系我们
系统管理: 中文环境 系统管理 桌面应用 内核技术 | Linux基础: 基础入门 安装配置 常用命令 经验技巧 软件应用 | Linux数据库: Mysql Postgre Oracle DB2 Sybase other
网络管理: 网络安全 网络应用 Linux服务器 环境配置 黑客安全 | 编程开发: PHP CC++ Python Perl Shell 嵌入式开发 java jsp | PHP技术: PHP基础 PHP技巧 PHP应用 PHP文摘
搜索中心 Linux招聘 Linux专题 Apache | Linux相关: 硬件相关 Linux解决方案 Linux认证 企业应用 其它Unix | 相关下载: 资料下载 参考手册 开发工具 服务器类 软路由 其它
 技术搜索:
会员中心 注册会员 高级搜索  
  → 当前位置:首页>linux数据库>oracle>正文

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

http://www.oklinux.cn  2007-11-12  ccidnet 638932  会员收藏  游客收藏  【 】 
您查看的文章来源于http://www.oklinux.cn

1.静态SQLSQL与动态SQL:

 

 

Oracle编译PL/SQL程序块分为两个种:其一为前期联编(early binding),即SQL语句在程序编译期间就已经确定,大多数的编译情况属于这种类型;另外一种是后期联编(late binding),即SQL语句只有在运行阶段才能建立,例如当查询条件为用户输入时,那么Oracle的SQL引擎就无法在编译期对该程序语句进行确定,只能在用户输入一定的查询条件后才能提交给SQL引擎进行处理。通常,静态SQL采用前一种编译方式,而动态SQL采用后一种编译方式。

 

 

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

 

 

2. 动态SQL程序开发:

 

 

理解了动态SQL编译的原理,也就把握了其基本的开发思想。动态SQL既然是一种”不确定”的SQL,那其执行就有其相应的特点。Oracle中提供了Execute immediate语句来执行动态SQL,语法如下:

 

 

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

 

 

对这一语句作如下说明:

 

 

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

 

 

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

 

 

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

 

 

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

 

 

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

 

 

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

 

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;

 

 

 

 

 

过程三:

共2页: 上一页 1 [2] 下一页

上一篇:轻松掌握Oracle Peeking 绑定变量的控制   下一篇:解析:JOB的Interval输入参数过长的问题

收藏于收藏夹】 【评论】 【推荐】 【打印】 【关闭
相关文档
·解析:JOB的Interval输入参数过长的问题
·轻松掌握Oracle Peeking 绑定变量的控制
·细化解析:怎样恢复一个丢失的 数据文件
·解析:物化视图刷新中出现的“约束冲突”
·解析:用dbv和RMAN检查数据文件中的坏块
·细化解析:怎样处理Oracle数据库中的坏块
·解析:如何正确的更改监听器日志文件名称
·怎样使用SQL Server数据库的查询累计值
·使用Flashback Query 恢复误删除的数据
·实例解析:怎样获得当前 数据库的SCN值
·怎样使用ERRORSTACK进行错误跟踪及诊断
·细化解析:时间再次停止运行的解决方法
·解析:怎样在Oracle 9i中正确的转换时区
·教你轻松掌握如何把数据导入不同的表空间
·实例解析:sqlldr加载数据到不同表的问题
·教你快速掌握Oracle 9i数据库的移动过程
发表评论
密码: 匿名评论
评论内容:

(不超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规)
 
  最新文档
·关于Oracle将目标数据库设为归档模式应
·Linux下OCI基础:配置Instant Client连
·Oracle中被锁定的解决办法
·Oracle 11G 无法连接到数据库实例故障
·浅谈创建Oracle数据库连接的两种方法
·如何从Oracle技术支持获得更多
·Oracle数据库中安全知识介绍
·Oracle推出Linux服务并不成功
·Oracle专用服务器的内存结构分布原则
·如何在RAC环境下修改Oracle字符集
·Oracle过程中执行动态SQL或DDL语句
·2008年Oracle错误、备份、升级等最热门
  阅读排行
·详解远程SHELL下安装配置RedHat ES 5的
·Ubuntu上安装Oracle 10G及相关配置
·Oracle高级复制(同步复制)配置步骤详细
·如何修改遗失的MySQL的ROOT用户密码
·Redhat Linux AS4 安装Oracle 10g(包括
·Linux下OCI基础:配置Instant Client连
·解决启动数据库时发生的ORA-12528错误
·在 Oracle Enterprise Linux 上升级到
·Oracle 10g表空间创建的完整步骤
·centos 5.0中成功安装Oracle10g (1020
·如何在RAC环境下修改Oracle字符集
·Oracle数据库导入导出方法的个人总结
·巧用Oracle执行计划机制提高查询性能
·Oracle 10g 在AIX 5.3上安装过程笔记
·Linux真机环境Oracle 10gR2 RAC 安装完
网摘收藏: