Oralce-PL/SQL编程-游标

PL/SQL(Procedural Language/SQL)是Oracle在数据库中引入的一种过程化编程语言。

PL/SQL块结构

  声明部分  执行部分(必须的)  异常处理部分

[declare]

  --声明部分,可选

BEGIN

  --执行部分,必须

[exception]

  --异常处理部分,可选

END

  单行注释:--

  多行注释:/*  */

基本数据类型:  

  number  varchar2  char  long  nchar nvarchar2  date  boolean

特殊数据类型:

  %type,声明一个与指定列名称相同的数据类型。

declare var_job emp.job%type;

  record:记录类型数据

type emp_type is record

(

var_ename varchar2(20),

var_job varchar2(20),

var_sal number

);

  %rowtype:结合了%type和record特性,可以根据数据表中的行结构定义一种特殊的数据类型,用来存储从数据表中检索到的一行数据

rowVar_emp emp%rowtype;定义能够存储emp表中一行数据的变量rowVar_emp

定义变量:var_countryname varchar2(50):=‘中国‘;

定义常量:con_day constant integer:=365;

PL/SQL游标

显示游标和隐式游标:

显示游标:例子

1.声明一个检索emp表中雇员信息的游标,然后打开游标,并指定检索职务是“MANAGER"的雇员信息,接着使用 fetch...into语句和while循环
读取游标中的所有雇员信息,最后输出读取的雇员信息

declare
cursor cur_emp(var_job in varchar2:=‘SALESMAN‘)
is select empno,ename,sal
from emp
where job=var_job;
type record_emp is record
(
var_empno emp.empno%type,
var_ename emp.ename%type,
var_sal emp.sal%type
);
emp_row record_emp;
begin
open cur_emp(‘MANAGER‘);
fetch cur_emp into emp_row; --读取游标中内容,将游标指针移动到结果集中的第一行
while cur_emp%found loop
dbms_output.put_line(emp_row.var_ename||‘的编号是‘||emp_row.var_empno||‘,工资是‘||emp_row.var_sal);
fetch cur_emp into emp_row;
end loop;
close cur_emp;
end;
/

游标属性:

  %found:如果SQL语句至少影响到一行数据,则该属性为true,否则为false

  %notfound:与上面的功能相反

  %rowcount:返回受影响的行数

  %isopen:游标打开时,返回true,关闭时,false

隐式游标

在执行一个SQL 语句时,Oracle会自动创建一个隐式游标。这个游标是内存中处理该语句的工作区域。

例子:

在SCOTT模式下,把emp表中销售员的工资上调20%,然后使用隐式游标sql的%rowcount属性输出上调
工资的员工数量

begin
update emp
set sal = sal*(1+0.2)
where job=‘SALESMAN‘;
if sql%notfound then
dbms_output.put_line(‘没有雇员调整工资‘);
else
dbms_output.put_line(‘有‘||sql%rowcount||‘个雇员工资上调20%‘);
end if;
end;
/

for语句循环游标:

例子:

使用隐式游标和for语句检索出职务是销售员的雇员信息并输出

begin
for emp_record in (select empno,ename,sal from emp where job=‘SALESMAN‘)
loop
dbms_output.put_line(‘雇员编号:‘||emp_record.empno);
dbms_output.put_line(‘; 雇员名称:‘||emp_record.ename);
dbms_output.put_line(‘; 雇员工资:‘||emp_record.sal);
end loop;
end;
/

使用显示游标和for语句检索出部门编号是30的雇员信息并输出

declare
cursor cur_emp is
select * from emp
where deptno=30;
begin
for emp_record in cur_emp
loop
dbms_output.put(‘雇员编号:‘||emp_record.empno);
dbms_output.put(‘雇员名称:‘||emp_record.ename);
dbms_output.put_line(‘雇员职务:‘||emp_record.job);
end loop;
end;
/

综上,在使用游标(隐式,显示)的for循环中,可以声明游标。但不用进行打开游标、读取游标、关闭游标等操作,这些由Oracle系统内部自动完成

 PL/SQL异常处理

在[exception]代码块中

根据异常产生的机制和原理,可将Oracle系统异常分为以下两大类:

1.预定义异常

  定义在Oracle的核心PL/SQL库中,用户可以在自己的PL/SQL异常处理部分使用名称对其进行标识。对这种异常情况的处理,用户无须在程序中定义,它们由Oracle自动引发。

系统预定义异常 说明
ZERO_DIVIDE 除数为零时引发的异常
ACCESS_INTO_NULL 企图为某个未初始化对象的属性赋值
COLLECTION_IS_NULL 企图使用未初始化的集合元素
CURSOR_ALREADY_OPEN 企图再次打开一个已经打开过的游标,但在重打开之前,游标未关闭
INVALID_CURSOR   执行一个非法的的游标操作,如,关闭一个未打开的游标
INVALID_NUMBER 企图将一个字符串转换成一个无效的数字而失败
LOGIN_DENIED 企图使用无效的用户名或密码连接数据库
NO_DATA_FOUND SELECT INTO 语句没有返回数据
ROWTYPE_MISMATCH 主游标变量与PL/SQL游标变量的返回类型不兼容
SELF_IS_NULL 使用对象类型时,使用空对象调用其方法
SUBSCRIPT_BEYOND_COUNT 元素下表超过嵌套表或VARRY中的元素
SUBSCRIPT_OUTSIDE_LIMIT 企图使用非法索引号引用嵌套表或VARRY中的元素
SYS_INVALID_ROWID 字符串向ROWID转换时的错误,因为该字符串不是一个有效的ROWID值
TIMEOUT_ON_RESOURCE Oracle在等待资源时超时
TOO_MANY_ROWS 执行SELECT INTO 语句时,结果集超过一行引发的异常

2.自定义异常

  有两种

A-错误编码异常

定义错误编码异常编号为“-00001”的异常变量,然后想dept表中插入一条能够“违反唯一性约束条件”的记录,

最后在exception代码中输出异常提示信息  

declare
primary_iterant exception;
pragma exception_init(primary_iterant,-00001);--关联错误号和异常变量名
begin
insert into dept values(10,‘软件开发部‘,‘深圳‘);
exception
when primary_iterant then
dbms_output.put_line(‘主键不允许重复!‘);
end;
/

B-业务逻辑异常

自定义一个异常变量,在向dept表中插入数据时,若判断loc字段为null,则使用raise语句引发异常,

并将程序执行流程转入到exception部分进行处理

declare
null_exception exception;
dept_row dept%rowtype;
begin
dept_row.deptno:=66;
dept_row.dname:=‘公共部‘;
insert into dept
values(dept_row.deptno,dept_row.dname,dept_row.loc);
if dept_row.loc is null then
raise null_exception;
end if;
exception
when null_exception then
dbms_output.put_line(‘loc字段的值不许为null‘);
rollback;
end;
/

  

时间: 2024-11-16 09:58:51

Oralce-PL/SQL编程-游标的相关文章

[推荐]ORACLE PL/SQL编程之四:把游标说透(不怕做不到,只怕想不到)

原文:[推荐]ORACLE PL/SQL编程之四:把游标说透(不怕做不到,只怕想不到) [推荐]ORACLE PL/SQL编程之四: 把游标说透(不怕做不到,只怕想不到) 继上两篇:ORACLE PL/SQL编程之八:把触发器说透 ORACLE PL/SQL编程之六:把过程与函数说透(穷追猛打,把根儿都拔起!) 得到了大家的强力支持,感谢.接下来再下猛药,介绍下一篇,大家一定要支持与推荐呀~!我也才有动力写后面的. 本篇主要内容如下: 4.1 游标概念 4.1.1 处理显式游标 4.1.2 处理

pl/sql编程基础

PL/SQL 1.过程.函数.触发器是pl/sql编写的 2.过程.函数.触发器是存放在oracle数据库中的 3.pl/sql是非常强大的过程化语言 4.过程.函数.触发器可以在java程序中调用 pl/sql编写能节省一点时间就是提高了性能(量大),java直接调用数据库存放的过程,解析时间就节省下来了,提高了性能 模块化的设计思想----->存储过程 网络传输(java程序中编写的sql语言),直接调用数据库的过程节省了传输量 提高安全性(存储过程避免了数据库信息的泄漏) 缺点: 移植性不

[顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之功)

原文:[顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之功) [顶]ORACLE PL/SQL编程详解之二: PL/SQL块结构和组成元素(为山九仞,岂一日之功) 继上四篇:ORACLE PL/SQL编程之八:把触发器说透                ORACLE PL/SQL编程之六:把过程与函数说透(穷追猛打,把根儿都拔起!)                [推荐]ORACLE PL/SQL编程之四:把游标说透(不怕做不到,只怕想不到) [推荐]

[推荐]ORACLE PL/SQL编程之五:异常错误处理(知已知彼、百战不殆)

原文:[推荐]ORACLE PL/SQL编程之五:异常错误处理(知已知彼.百战不殆) [推荐]ORACLE PL/SQL编程之五: 异常错误处理(知已知彼.百战不殆) 继上三篇:ORACLE PL/SQL编程之八:把触发器说透 ORACLE PL/SQL编程之六:把过程与函数说透(穷追猛打,把根儿都拔起!) [推荐]ORACLE PL/SQL编程之四:把游标说透(不怕做不到,只怕想不到) 得到了大家的强力支持与建议,万分感谢.接下来介绍下一篇:oracle pl/sql异常处理部分,还望大家一定

【强烈强烈推荐】《ORACLE PL/SQL编程详解》全原创(共八篇)--系列文章导航

原文:[强烈强烈推荐]<ORACLE PL/SQL编程详解>全原创(共八篇)--系列文章导航 <ORACLE PL/SQL编程详解> 系列文章目录导航 ——通过知识共享树立个人品牌. 本是成书的,但后来做其他事了,就无偿的贡献出来,被读者夸其目前为止最“实在.经典”的写ORACLE PL/SQL编程的文章-! 觉得对你有帮助,请留言与猛点推荐,谢谢. [推荐]ORACLE PL/SQL编程详解之一:PL/SQL 程序设计简介(千里之行,始于足下) 本篇主要内容如下:第一章 PL/S

[推荐]ORACLE PL/SQL编程详解之三:PL/SQL流程控制语句(不给规则,不成方圆)

原文:[推荐]ORACLE PL/SQL编程详解之三:PL/SQL流程控制语句(不给规则,不成方圆) [推荐]ORACLE PL/SQL编程详解之三: PL/SQL流程控制语句(不给规则,不成方圆) ——通过知识共享树立个人品牌. 继上五篇: [顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之功) [推荐]ORACLE PL/SQL编程之四:把游标说透(不怕做不到,只怕想不到) [推荐]ORACLE PL/SQL编程之五:异常错误处理(知已知彼.百战不

[推荐]ORACLE PL/SQL编程详解之一:PL/SQL 程序设计简介(千里之行,始于足下)

原文:[推荐]ORACLE PL/SQL编程详解之一:PL/SQL 程序设计简介(千里之行,始于足下) [推荐]ORACLE PL/SQL编程详解之一: PL/SQL 程序设计简介(千里之行,始于足下) ——通过知识共享树立个人品牌. 继上六篇: [顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之功) [推荐]ORACLE PL/SQL编程详解之三:PL/SQL流程控制语句(不给规则,不成方圆) [推荐]ORACLE PL/SQL编程之四:把游标说透(

[强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!)

原文:[强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!) [强烈推荐]ORACLE PL/SQL编程详解之七: 程序包的创建与应用(聪明在于学习,天才在于积累!) ——通过知识共享树立个人品牌.   继上七篇:            [推荐]ORACLE PL/SQL编程详解之一:PL/SQL 程序设计简介(千里之行,始于足下)            [顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之

ORACLE PL/SQL编程之八(一): 把触发器说透

本篇主要内容如下: 8.1 触发器类型 8.1.1 DML触发器 8.1.2 替代触发器 8.1.3 系统触发器 8.2 创建触发器 8.2.1 触发器触发次序 8.2.2 创建DML触发器 8.2.3 创建替代(INSTEAD OF)触发器 8.2.3 创建系统事件触发器 8.2.4 系统触发器事件属性 8.2.5 使用触发器谓词 8.2.6 重新编译触发器 8.3 删除和使能触发器 8.4 触发器和数据字典 8.5   数据库触发器的应用举例 触发器是许多关系数据库系统都提供的一项技术.在O

PL/SQL 编程(二)

1    For循环 语法:begin for i in reverse 1..10 loop insert into users values(i,'奥巴马'): end loop: end; 注意:循环变量 i 是隐含增加的,所以无法看到 2    goto语句 goto 语句用于跳转到特定的位置去执行语句.由于goto语句会减少程序的可读性,所以一般情况下 不建议使用goto语句 3    null语句 null语句不会执行任何操作,但是可以增加程序的可读性 4    创建返回值是一个结果