- 浏览: 146924 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
陈碧滔:
java获取工程目录路径 -
stevenjohn:
楼主能上传一下源代码吗?
ActiveMQ5.0实战三:使用Spring发送,消费topic和queue消息 -
指挥家:
讲的很好!
Foxmail6收发Web mail邮箱邮件实现原理 -
azhqiang:
谢谢你啊。呵呵
flex最全的表单验证
Oracle在数据库中引入了一种过程化编程语言,称为PL/SQL(Procedural Language/SQL).PL/SQL构建与SQL之上,可以用来编写包含SQL语句程序。其中包含这类语言的标准编程结构如下:
- 块结构
- 变量和类型
- 条件逻辑
- 循环
- 游标,其中保存着查询返回的结果
- 过程
- 函数
- 包,可以用来将过程和函数组合到一个单元中
通常,PL/SQL用于向数据库中加入业务逻辑。这种集中化的代码可以由任何能够访问数据库的程序调用,其中就包括C程序和Java程序。
块结构
PL/SQL程序可划分成称为块的结构,每一个块包含有PL/SQL和SQL语句。典型的PL/SQL代码包含如下的结构:
- [DECLARE
- declaration_statements
- ]
- BEGIN
- executable_statements
- [EXCEPTION
- exception_handing_statements
- ]
- END;
[DECLARE declaration_statements ] BEGIN executable_statements [EXCEPTION exception_handing_statements ] END;
声明和异常块是可选的,上述语法中的解释如下:
- declaration_statements 包含在声明块中,它负责声明该块其他部分将会使用的变量。这个变量对这个块来说是局部变量,也就是说不能从块的外部来访问这些变量。声明块总是放在块的开始位置。
- executable_statements 是块中实际可执行的语句。
- exception_handing_statements 中的语句负责处理可执行语句中可能发生的任何错误。
每一条语句都有分号结尾,整个块由关键字END标志结束。先看一个简单的例子:
- -- Created on 2010-5-20 by ADMINISTRATOR
- declare
- -- Local variables here
- width INTEGER;
- height INTEGER:=2;
- area INTEGER;
- i integer;
- begin
- -- Test statements here
- area:=6;
- width:=area/height;
- DBMS_OUTPUT.put_line('width='||width);
- EXCEPTION
- WHEN ZERO_DIVIDE THEN
- DBMS_OUTPUT.put_line('Division by zero');
- end;
-- Created on 2010-5-20 by ADMINISTRATOR declare -- Local variables here width INTEGER; height INTEGER:=2; area INTEGER; i integer; begin -- Test statements here area:=6; width:=area/height; DBMS_OUTPUT.put_line('width='||width); EXCEPTION WHEN ZERO_DIVIDE THEN DBMS_OUTPUT.put_line('Division by zero'); end;
变量和类型
变量声明中包含名称和类型,还可以通过%TYPE关键字定义变量类型,这个关键字告诉PL/SQL使用与表中指定列相同的类型。下面这个例子用%TYPE声明了一个变量,这个变量类型与product表中price列类型相同。
product_price product.price%TYPE
条件逻辑
在PL/SQL中,IF、THEN、ELSE、ELSIF和ENDIF等关键字用于执行条件逻辑。下面的语法说明了条件逻辑的用法:
IF condition1 THEN statement1 ELSIF condition2 THEN statement2 ELSE statement3 END IF;
循环
PL/SQL中包含三种循环:
简单循环:直到显式结束循环前一直运行。
WHILE循环:直到某个特定条件出现之前一直运行。
FOR循环:运行预先确定的次数。
简单循环
LOOP statements END LOOP;
要结束简单循环,可以使用EXIT或者EXIT WHEN语句。EXIT语句立即结束循环,EXIT WHEN语句在指定条件出现时结束循环。 举个简单例子:
LOOP counter:=counter+1; EXIT WHEN counter=5; END LOOP;
WHILE循环
WHILE循环在某个特定条件出现之前一直运行。
举个例子:
counter=0; WHILE counter<6 LOOP counter:=counter+1; END LOOP;
FOR循环
FOR循环会运行预先确定的次数,可通过给循环变量指定上限和下限来确定循环运行的次数,然后,循环变量在每次循环中递增或递减。语法如下:
FOR loop_variable IN [REVERSE] lower_bound ..upper_bound LOOP statements END LOOP;
如果使用了REVERSE则loop_variable每次减少1。
游标
当SELECT语句从数据库中返回的记录多余一条时,就可以使用游标。使用游标需要遵循以下5个步骤:
(1)声明一些变量,用于保存SELECT语句返回的列值。
(2)声明游标,并指定SELECT语句。
(3)打开游标。
(4)从游标中获取记录。
(5)关闭游标。
- declare
- v_username amc_base_user.user_name%TYPE;
- CURSOR v_user_cursor IS
- SELECT user_name FROM amc_base_user;
- begin
- OPEN v_user_cursor;
- LOOP
- FETCH v_user_cursor
- INTO v_username;
- EXIT WHEN v_user_cursor%NOTFOUND;
- DBMS_OUTPUT.put_line(v_username);
- END LOOP;
- CLOSE v_user_cursor;
- end;
declare v_username amc_base_user.user_name%TYPE; CURSOR v_user_cursor IS SELECT user_name FROM amc_base_user; begin OPEN v_user_cursor; LOOP FETCH v_user_cursor INTO v_username; EXIT WHEN v_user_cursor%NOTFOUND; DBMS_OUTPUT.put_line(v_username); END LOOP; CLOSE v_user_cursor; end;
注意:
1 声明完游标后此时游标并未打开,只有OPEN的时候才打开。
2 为了确定循环是否结束,可以使用布尔变量%NOTFOUND。当FETCH语句到达游标的最后一条记录时,这个变量为真。
3 游标使用完之后要及时关闭掉。
利用FOR循环的功能,可以增强在游标中访问记录的能力。当使用FOR循环时,可以不显式地打开和关闭游标----FOR循环会自动执行这些操作。
- declare
- v_username amc_base_user.user_name%TYPE;
- CURSOR v_user_cursor IS
- SELECT user_name FROM amc_base_user;
- begin
- FOR v_u IN v_user_cursor LOOP
- DBMS_OUTPUT.put_line(v_u.user_name);
- END LOOP;
- end;
declare v_username amc_base_user.user_name%TYPE; CURSOR v_user_cursor IS SELECT user_name FROM amc_base_user; begin FOR v_u IN v_user_cursor LOOP DBMS_OUTPUT.put_line(v_u.user_name); END LOOP; end;
发表评论
-
Oracle导出导入dmp文件(转)
2010-11-17 13:41 4612Oracle数据导入导出imp/exp ... -
row_number over(partition by col1 order by col2)
2010-10-28 11:16 1843row_number() OVER (PARTITION BY ... -
orcle中sys_connect_by_path的用法
2010-10-28 10:21 941sys_connect_by_path的几种 ... -
使用plsql一些常见的操作
2010-09-01 23:51 957/**创建一个访问分析表*/ create table Ac ... -
oracle函数手册(带示例)
2010-07-30 15:12 730oracle函数手册 SQL中的单记录函数 1.ASCII 返 ... -
Oracle分析函数参考手册[下][转载自JavaEye]
2010-07-30 15:08 795=============================== ... -
Oracle分析函数参考手册[上][转载自JavaEye]
2010-07-30 15:07 742=============================== ... -
Oracle 分析函数的使用(zt)
2010-07-30 15:07 6452/11/2005 09:43 FPOracle 分析函数使用 ... -
Oracle分析函数参考手册
2010-07-30 15:06 65722/06/2005 12:22 FP Oracle从8.1. ... -
Oracle函数列表速查
2010-07-30 15:03 635PL/SQL单行函数和组函数详解 函数是一种有零个或多个参数 ... -
oracle分析函数(3)
2010-07-30 14:59 746【2】找出每个区域订单总额排名前3的大客户: SQL &g ... -
oracle分析函数(2)
2010-07-30 14:58 756注意这里有3条记录的订单总额是一样的。假如我们现在需要筛选排名 ... -
oracle分析函数(1)
2010-07-30 14:57 688一.分析函数(OVER) 目录: ============ ... -
用SQL语句添加删除修改字段
2010-07-27 14:19 1328增加字段alter table docdsp add dsp ... -
oracle 存储过程的基本语法
2010-07-13 18:57 6591.基本结构 CREATE OR REPLACE PROCED ... -
oracle 字符串连接
2010-06-28 15:26 841字符串连接 SQL> select 'abc' || ' ... -
系统重装后,oracle数据库中数据快速恢复
2010-06-18 15:56 14511. 准备工作把旧的ORACLE所有文件都COPY备份下来 ... -
SELECT INTO 和 INSERT INTO SELECT 两种表复制语句
2010-06-06 19:05 754Insert是T-sql中常用语句,Insert ... -
Oracle字符串处理函数
2010-06-02 19:27 1285项目中有涉及存储过程对字符串的处理,所以就将在网上查找到的资料 ...
相关推荐
PL/SQL 编程基础知识详解,PL/SQL 包含过程化语句和SQL语句数据操作和查询语句被包含在PL/SQL代码的程序单元中(PL/SQL块),经过逻辑判断、循环等操作完成复杂的功能或者计算.。
ORACLE PL/SQL编程之八ORACLE PL/SQL编程之八ORACLE PL/SQL编程之八ORACLE PL/SQL编程之八
PL/SQL编程教程电子书,全册,完整版。。。。
pl/sql编程基础教程,内容丰富,适合初学者学习。
oracle pl/sql 编程大全,希望能对想学oracle或者oracle新手以及需要用到这方面知识的朋友有点帮助。
pl/sql 编程和oracle的函数查询,非常好用,欢迎下载
Oracle PL/SQL实例编程 Oracle PL/SQL实例编程 Oracle PL/SQL实例编程
PL/SOL是Oracle特有的编程语言,它不仅具有过程编程语言的基本特征(循环、条件分支等),而且还...本书不仅适合于PL/SQL初学者,而且也适合于有经验的PL/SQL编程人员,本书还可以作为Oracle培训班的教材或者辅助材料。
《Oracle PL/SQL程序设计(第5版)》基于Oracle数据库11g,从PL/SQL编程、PL/SQL程序结构、PL/SQL程序数据、PL/SQL中的SQL、PL/SQL应用构建、高级PL/SQL主题这6个方面详细系统地讨论了PL/SQL以及如何有效地使用它。...
Oracle PL/SQL 编程手册Oracle PL/SQL 编程手册
《Oracle PL/SQL程序设计(第5版)(套装上下册)》基于Oracle数据库11g,从PL/SQL编程、PL/SQL程序结构、PL/SQL程序数据、PL/SQL中的SQL、PL/SQL应用构建、高级PL/SQL主题这6个方面详细系统地讨论了PL/SQL以及如何...
pl/sal编程简介,介绍了pl/sql编程所用的基本语法,循环,条件,异常处理,自定义异常等等
如今,有越来越多的商业逻辑和应用逻辑转向了Oracle Server,因此,PL/SQL编程也成了整个开发过程的一个重要组成部分。PL/SQL Developer侧重于易用性、代码品质和生产力,充分发挥Oracle应用程序开发过程中的主要...
12oracle的PL/SQL编程-函数.包.触发器 PPT 12oracle的PL/SQL编程-函数.包.触发器 PPT
《oracle database 11gpl/sql编程实战》通过动手练习、大量的示例以及实际的项目帮助读者掌握pl/sql。书中包含大量最佳实践,涵盖了pl/sql语言所有的最新功能和改进之处。每章末尾配有测验题,可以帮助读者进一步...
Oracle PL/SQL 编程手册(SQL大全), 学习Oracle有用。
PL/SQL本身涉及的知识点浩瀚、庞杂,初学者根本无法依靠自身能力理清头绪,学习成本极高.本书对知识点进行了体系化的梳理,化繁杂为有序,突出重点,直指核心,循序渐进,尽可能为学习者提供“捷径”,仅仅只是这...
15oracle的PL/SQL编程-分页 PPT 15oracle的PL/SQL编程-分页 PPT
内容包括(1)PL/SQL简介(2)PL/SQL语法(3)存储过程(4)触发器(5)游标(6)包(7)函数七部分。如果你是初学者,很快时间就可以掌握PL/SQL了。相信我,没错的!