动态网站制作指南
[  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
电脑书籍下载:程序设计书籍 | 数据库教程书籍 | 平面与多媒体书籍 | 网络通讯书籍 | 系统管理书籍 | 网络安全书籍 | 认证考试书籍
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库学院 > 数据库技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Access教程,DB2教程,数据库安全,数据库文摘
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ 数据库技巧 ]的信息



本月文章推荐
.讲解SQL Server的分布式跨服务器.
.同时安装sql2000和sql2005,经验点.
.将表数据生成SQL脚本的存储过程.
.SQLServer中有关SQLAgent的使用技.
.配置SQL Server 2000选项.
.在特定情况下使用游标改善语句执.
.Web环境下的SQL Server数据备份与.
.放弃连接消息出现在错误日志中的.
.使用Microsoft SQL Server 2000的.
.SELECT查询的应用(一).
.SQL Server 2008与Microsoft数据.
.教你如何用SQL备份和还原数据库.
.在SQL Server 2005中用存储过程实.
.SQL Server编写存储过程小工具(二.
.讲解使用SQL Server升级顾问的详.
.数据库中为什么会出现_WA_Sys_开.
.sql语句查询结果合并union all用.
.把Excel表中数据导入数据库 .
.SQL Server 2000的数据转换服务(.
.在SQL Server中获得不包含时间部.

动态SQL的编译原理与基本开发思想的关系

文章类别:数据库技巧 | 发表日期:2008-5-10 |


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;

过程三:

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;

注意:在过程二中的动态SQL语句使用了占位符“:1“,其实它相当于函数的形式参数,使用”:“作为前缀,然后使用using语句将p_id在运行时刻将:1给替换掉,这里p_id相当于函数里的实参。另外过程三中打开的游标为动态游标,它也属于动态SQL的范畴,其整个编译和开发的过程与 execute immediate执行的过程很类似,这里就不在赘述了。


上一篇:通过sp_sysmon对Sybase进行性能诊断 人气:288
下一篇:教你快速掌握分别删除数据表记录的方法 人气:179
点击此处浏览全部数据库的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-5-20 站长俱乐部新闻发布系统 v5.19
2008-5-20 DotNetTextBox网页编辑器 v3.4.7
2008-5-20 phpMyFAQ v2.5.0 多国语言版
2008-5-20 DreamArticle 文章管理系统 v2.0
2008-5-20 Drupal v7.xdev Build080518
2008-5-20 逐迹内容管理系统AspxNuke v2.0.
2008-5-20 ajax奥运留言本 v1.0
2008-5-20 QQ空间博客全自动挂机互踩好友
2008-5-20 网人采集 v1.2.0
2008-5-7 Windows XP SP3 官方英文版
2008-5-7 Windows XP SP3 官方香港中文版
2008-5-7 Windows XP SP3 官方繁体中文版
2008-5-7 Windows XP SP3 官方简体中文版
2008-4-30 Multiple Unzip Wizard 1.02
2008-4-30 Multiple Unrar Wizard 1.0.0
2008-4-30 WinZip Install/Try/Uninstall a
2008-4-30 ZIP压缩文件修复器WzipFix 2.0
2008-4-30 Pentazip 6.01 Build 189 For Wi
  发表评论
姓 名: 验证码: [ 全部贴吧 ] [ 浏览评论 ]
内 容:
[ 汉字翻译拼音 ] [ 广告代码 ] [ 符号对照表 ] [ 进制转换 ] [ 经典小工具 ] [ 个税计算 ] [ 汉字简繁转换 ] [ 普通单位换算 ] [ 公制单位换算 ]
[ 生辰老黄历 ] [ 国内电话区号 ] [ 国家代码与域名缩写 ] [ 文字加密解密 ] [ 健康查询 ] [ 万年历 ] [ 手机号码查询 ] [ ip搜索 ] [ Google PR查询 ]
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号