PL/SQL 编程(二)
版权声明:本文为博主原创文章。未经博主同意不得转载。 https://blog.csdn.net/u011685627/article/details/26299399
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 创建返回值是一个结果集的存储过程
(1) 创建一个包:
SQL> create or replace package testpackage as
type test test_cursor is ref cursor;
end testpackage;
(2) 创建存储过程
SQL> create or replace procedure sp_procedure1
(stuNo in number, param_cursor out testpackage.test_cursor) is
begin
open param_cursor for select * from emp where sutno=stuNo;
end;
5 分页
(1) sql语句
select * from
(select *,rownum NO from
(select * from emp) where rownum <=20) where rownum >=10;
(2) 创建一个包
create or replace package testpackage2 as
type test test_cursor is ref cursor;
end testpackage2;
(3) 创建存储过程
SQL> create or replace procedure procedureName2
(tableName in varchar2, -- 表名
pageSize in number, -- 每页显示的记录数
pageNow in number, -- 当前是第几页
pageCount out number, -- 总页数
p_cursor out testpackage2.test_cursor) is
v_sql varchar2(1000);
v_beginNum number := (pageNow -1)* pageSize + 1;
v_endNum number := pageNow * pageSize;
begin
v_sql := 'select * from (select *,rownum NO from (select * from '|| tableName ||')
where rownum <= '|| v_endNum ||') where rownum >= '|| v_beginNum;
open p_cursor for v_sql;
-- 创建一个sql语句
v_sql := 'select count(*) from ' || tableName;
-- 运行sql语句,将结果保存
execute immediate v_sql into rows。
if mod(rows,pageSize) = 0
then pageCount := rows / pageSize;
else
pageCount := rows / pageSize + 1;
end if;
-- 关闭游标
close p_cursor;
end;
6 异常处理
(1) 提前定义异常
(2) 非提前定义异常
(3) 自己定义异常
例1
SQL> declare v_name emp.ename%type;
begin
select ename into v_name from emp where empno = &no;
dbms_output.put_line('名字:' || v_name);
exception
when no_data_found
then dbms_output.put_line('编号没有!
');
end;
提前定义异常
a case_not_found
在编写case 语句时。假设在when子句中没有包括必须的条件分支(没有符合条件的)。就会触发case_not_found异常
b cursor_already_open
当又一次打开已经打开的游标时触发此异常
c dup_val_on_index
在唯一索引所相应的列上插入反复值时触发此异常
d invalid_cursor
当试图在不合法的游标上进行操作时触发此异常
e invalid_number
当输入的数字无效时触发此异常
f too_many_rows
当返回值不止是一条记录时触发此异常
g zero_divide
当进行 x/0,即除数为零的操作时触发此异常
h value_error
当进行赋值操作时,假设变量的长度不足以存储实际数据时触发此异常
i login——denide
当用户非法登录时会触发此异常
j not_logged_on
假设用户没有登录就运行DML操作,就会触发此异常
k storage_error
假设超出了内存空间,就会触发此异常
l timeout_on_resource
当Oracle等待资源时。假设发生超时情况,就会触发此异常
自己定义异常
SQL> create or replace procedure procedureName2(sp_empNo number) is
MyExpception Exceptiom; -- 自己定义一个异常
begin
update emp set sal = sal * 1.2 where empno = &no;
if sql%notfound then
raise MyExpception; -- 触发自己定义异常
end if;
exception
when no_data_found
then dbms_output.put_line('没有更新数据!
');
end;
PL/SQL 编程(二)的更多相关文章
- [顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之功)
原文:[顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之功) [顶]ORACLE PL/SQL编程详解之二: PL/SQL块结构和组成元素(为山九仞,岂一日 ...
- ORACLE PL/SQL编程详解
ORACLE PL/SQL编程详解 编程详解 SQL语言只是访问.操作数据库的语言,并不是一种具有流程控制的程序设计语言,而只有程序设计语言才能用于应用软件的开发.PL /SQL是一种高级数据库程序设 ...
- pl/sql编程
body { font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI ...
- [强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!)
原文:[强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!) [强烈推荐]ORACLE PL/SQL编程详解之七: 程序包的创建与应用(聪明在于学习,天 ...
- ORACLE PL/SQL编程之六:把过程与函数说透(穷追猛打,把根儿都拔起!)
原文:ORACLE PL/SQL编程之六:把过程与函数说透(穷追猛打,把根儿都拔起!) ORACLE PL/SQL编程之六: 把过程与函数说透(穷追猛打,把根儿都拔起!) 继上篇:ORACLE P ...
- [推荐]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 ...
- 【强烈强烈推荐】《ORACLE PL/SQL编程详解》全原创(共八篇)--系列文章导航
原文:[强烈强烈推荐]<ORACLE PL/SQL编程详解>全原创(共八篇)--系列文章导航 <ORACLE PL/SQL编程详解> 系列文章目录导航 ——通过知识共享树立个人 ...
- [推荐]ORACLE PL/SQL编程详解之一:PL/SQL 程序设计简介(千里之行,始于足下)
原文:[推荐]ORACLE PL/SQL编程详解之一:PL/SQL 程序设计简介(千里之行,始于足下) [推荐]ORACLE PL/SQL编程详解之一: PL/SQL 程序设计简介(千里之行,始于足下 ...
随机推荐
- 在ASPNETCORE中获得所有Action
在ASPNETCORE中获得所有Action 本文旨在记录自己在aspnetcore工作中需要获取所有Action,在查询了资料后进行了几种方法的记录.后期有发现其它方式再进行追加. 一.通过 反射 ...
- [转]OLAP的12条准则
OLAP的12条准则 Multidimensional conceptual view OLAP模型必须提供多维概念视图 User-analysts would view an enterprise ...
- 第六章使用java实现面向对象-集合框架
一:接口:即表示集合的抽象数据类型. 实现:即集合框架中接口的实现. 算法:在一个实现了某个集合框架中的接口的对象身上完成某种有用的计算的方法,例如查找. 排序等. Collection 接口存储一组 ...
- 使用eclipse创建maven web项目
1.新建项目: 2.选择模板: 3.输入项目信息: 4.新建的项目结构,发现index.jsp报错,直接删除重新创建一个index.jsp文件后,发现仍然报错,再在pom/xml文件中添加相应的ser ...
- 阿里云服务器(ECS)购买及配置总结
云服务器是一种简单高效.安全可靠.处理能力可弹性伸缩的计算服务.其管理方式比物理服务器更简单高效.用户无需提前购买硬件,即可迅速创建或释放任意多台云服务器. 目前比较知名的与服务器提供商有:阿里云.百 ...
- Spring事务不起作用原因
首先声明: Checked异常继承java.lang.Exception类.Unchecked异常继承自java.lang.RuntimeException类. 而,Spring的事务实现采用基于AO ...
- Java使用反射来获取成员变量泛型信息
Java通过指定类对应的Class对象,程序可以获得该类里包括的所有Field,不管该Field使用private修饰,还是使用public修饰.获得了Field对象后,就可以很容易的获得该Field ...
- 怎样关闭占用80端口的pid为4的进程
我也被这个问题给纠结了好几天.重装系统都三次了.终于找到原因了:我用的是sqlserver 2008;解决方法:window-sqlserver 2008-配置工具-sqlserver 配置管理器 找 ...
- 移动web开发ajax缓存操作
移动web开发过程中网速是必须考虑的一个因素,所以一般是尽可能的在本地存储数据,避免弱网环境下请求数据失败导致页面没有内容的情况. 前后端分离是web开发的必然趋势,在PC端我们有时甚至为了避免aja ...
- VS2010环境开发Teamcenter ITK
前言 这篇文章主要是用Teamcenter ITK开发的入门配置教程.几个月前学习ITK开发时,领导要求将配置过程整理成学习笔记.最近同事要做ITK开发,就发给他了.感觉这篇文章对别人还是有帮助的,决 ...