【Oracle】存储过程写法小例子
1、存储过程的基本语法:
CREATE OR REPLACE PROCEDURE 存储过程名(param1 in type,param2 out type)
IS
变量1 类型(值范围);
变量2 类型(值范围);
BEGIN
select count(*) into 变量1 from 表名 where 列名=param1;
if (判断条件) then
select 列名 into 变量2 from 表名 where 列名=param1;
DBMS_OUTPUT.put_line('打印信息');
Elsif (判断条件) then
dbms_output.put_line('打印信息');
Else
Raise 异常名 (NO_DATA_FOUND);
End if;
Exception
When others then
Rollback;
END;
2、已命名的异常:
命名的系统异常 产生原因
ACCESS_INTO_NULL 未定义对象
CASE_NOT_FOUND CASE中若未包含相应的WHEN,并且没有设置ELSE时
COLLECTION_IS_NULL 集合元素未初始化
CURSER_ALREDAY_OPEN 游标已经打开
DUP_VAL_NO_INDEX 唯一索引对应的列上有重复的列
INVALID_CUSER 在不合法的游标上操作
INVALID_NUMBER 内嵌的SQL语句不能将字符转换为数字
NO_DATA_FOUND 使用select into 未返回行,或应用索引表未初始化
TOO_MANY_ROWS 执行select into 时,结果集超过一行
ZERO_DIVIDE 除数为0
SUBSCRIPT_BEYOND_COUNT 元素下标超过嵌套表或VARRAY的最大值
SUBSCRIPT_OUTSIDE_LIMIT 使用嵌套表或VARRAY时,将下标指定为负数
VALUE_ERROR 赋值时,变量长度不足以容纳实际数量
LOGIN_DENIED PL/SQL应用程序连接到ORACLE数据库时,提供了不正确的用户名和密码
NO_LOGGED_ON PL/SQL应用程序在没有连接ORACLE数据库的情况下访问数据
PROGRAM_ERROR PL/SQL内部问题,可能需要重装数据字典& PL/SQL系统包
ROWTYPE_MISMATCH 宿主游标变量与PL/SQL游标变量的返回类型不兼容
SELF_IS_NULL 使用对象类型时,在NULL对象上调用对象方法
STORAGE_ERROR 运行PL/SQL时,超出内存空间
SYS_INVALID_ID 无效的ROWID字符串
TIMEOUT_ON_RESOURCE ORACLE在等待资源时超时
3、实际例子
2.1 没有参数的过程
create or replace procedure test_count
is
v_total int;
v_date varchar(20);
begin
select count(*) into v_total from dual;
select to_char(sysdate,'yyyy-mm-dd') into v_date from dual;
DBMS_OUTPUT.put_line('总人数:'||v_total);
DBMS_OUTPUT.put_line('当前时间:'||v_date);
end;
调用方法:
begin
test_count;
end;
2.2 仅带传入参数的过程
create or replace procedure test_count1(v_id in varchar2)
as
v_name varchar(100);
begin
select c_name into v_name from tb_store where c_stono=v_id;
DBMS_OUTPUT.put_line(v_id||'店的名称为:'||v_name);
exception
when no_data_found then dbms_output.put_line('no_data_found');
end;
调用方法:
begin
test_count1(11910);
end;
2.3 仅带输出参数的过程
create or replace procedure test_count2(v_name out varchar2)
is
begin
select c_name into v_name from tb_store where c_stono='1101';
exception
when no_data_found then dbms_output.put_line('no_data_found');
end;
调用方法:
declare
v_name varchar(200);
begin
test_count2(v_name);
dbms_output.put_line(v_name);
end;
2.4 带输入参数和输出参数的存储过程
create or replace procedure test_count3(v_id in int,v_name out varchar2)
is
begin
select c_name into v_name from tb_store where c_stono=v_id;
dbms_output.put_line(v_name);
exception
when no_data_found then dbms_output.put_line('no_data_found');
end;
调用方法:
declare
v_name varchar(200);
begin
test_count3('1101',v_name);
end;
2.5 带异常输出的存储过程
【Oracle】存储过程写法小例子的更多相关文章
- Oracle存储过程写法
create or replace procedure QIANFEIGL_JIAOKUANDY( cebenh varchar2, kehuh varchar2, hetongh varchar2, ...
- oracle 存储过程和函数例子
关于 游标 if,for 的例子 create or replace procedure peace_if is cursor var_c is select * from grade; begin ...
- oracle 存储过程和函数例子 --2
关于 游标 if,for 的例子 create or replace procedure peace_if is cursor var_c is select * from grade; begin ...
- oracle存储过程写法。
create or replace procedure testwzm(v_gdjdm in varchar2) isv_id varchar2(10);v_xlname varchar2(100); ...
- Oracle 动态sql小例子
错误写法: create or replace procedure testproce20130228issqlstr varchar2(8000);date1 varchar2(10);begins ...
- oracle触发器的小例子
实现功能: 插入数据前触发,检查与插入数据几个属性相同的在表中的列将状态改为false,再执行插入. 解决方案: CREATE OR REPLACE TRIGGER tri_insert BEFORE ...
- Oracle存储过程入参传入List集合的小例子
第一步:创建一个对象类型 create or replace type STUDENT as object( id ), name ), age ) ); / 第二步:创建一个数组类型 (任意选择下面 ...
- oracle存储过程的例子
oracle存储过程的例子 分类: 数据(仓)库及处理 2010-05-03 17:15 1055人阅读 评论(2)收藏 举报 认识存储过程和函数 存储过程和函数也是一种PL/SQL块,是存入数据库的 ...
- Oracle存储过程(增、删、改)写法、oracle执行存储过程
Oracle存储过程(增.删.改)写法 发布时间: 2010-3-24 11:07 作者: ZHF 来源: 51Testing软件测试网采编 字体: 小 中 大 | 上一篇 下一篇 ...
随机推荐
- web前端html快速入门
HTML 学前端之间不得不知道一个网站:http://www.w3school.com.cn/ 网上有很多教程关于前端的,写的特别详细,也写的特别好.我们应该要自已理解,一些相应的前端的知识,不能只是 ...
- 国内maven仓库地址资源汇总
国内maven仓库地址:阿里云maven仓库,网易163maven仓库,以及其他maven仓库地址. 国内下载maven一般速度都很慢,下载需要很久时间.这里汇总了一些国内的镜像资源 附带pom文件中 ...
- 数据库-转换sql语句
文章描述:主要说明转换成SQL语句的过程.----必要信息(数据库名,表名,条件)转换成SQL语句 一些界面上数据增删改查的操作往往只需要输入一数据库名,表名,加条件就可以进行数据查询了,在这背后是怎 ...
- ArrayList的subList方法
参考博文使用java.util.List.subList时最好小心点 List接口中定义: List<E> subList(int fromIndex, int toIndex); 英文注 ...
- Oracle 12c 操作 CDB PDB
CREATE TRIGGER open_all_pdbs AFTER STARTUP ON DATABASE BEGIN EXECUTE IMMEDIATE 'alter pluggable data ...
- Hive是什么
Hive是什么1)Hive 是建立在Hadoop (HDFS/MR)上的用于管理和查询结果化/非结构化的数据仓库:2)一种可以存储.查询和分析存储在Hadoop 中的大规模数据的机制:3)Hive 定 ...
- imx6的kernel3.4.15启动流程
//最开始的定义为 DT_MACHINE_START(IMX6Q, "Freescale i.MX6 Quad/DualLite (Device Tree)") .smp = sm ...
- [转]一步步学习EF Core(2.事务与日志)
本文转自:http://www.cnblogs.com/GuZhenYin/p/6862505.html 上节我们留了一个问题,为什么EF Core中,我们加载班级,数据并不会出来 其实答案很简单,~ ...
- MySQL死锁检测和回滚
最近碰到“TOO DEEP OR LONG SEARCH IN THE LOCK TABLE WAITS-FOR GRAPH, WE WILL ROLL BACK FOLLOWING TRANSACT ...
- IList,ICollection,IEnumerable,IEnumerator,IQueryable
http://www.cnblogs.com/edison1105/archive/2012/07/30/2616082.html 1.首先看一个简单的例子 int[] myArray = { 1, ...