Oracle存储过程及举例(几种参数情况的存储过程)

Oracle存储过程及举例(几种参数情况的存储过程)Oracle存储过程及举例(几种参数情况的存储过程)

大家好,又见面了,我是你们的朋友全栈君。

存储过程
存储过程可以有多个或者零个输入输出参数,但通常没有返回值。存储过程是已经编译好的代码,所以执行效率非常高
存储过程创建语句

 

create [or replace] procedure 存储过程名 [(输入、输出参数、in/out模式参数)]
is/as
begin
sentences;
[exception
 sentences;]
end 存储过程名;

举例一个没有参数的存储过程

 

create or replace procedure pro_no_par is
begin
update employees set salary=salary+100 where employee_id=100;
commit;
dbms_output.put_line('工资已经调整!!');
end pro_no_par;

结果:

 

begin
pro_no_par;
end;
匿名块已完成
工资已经调整!!

举例一个带in模式参数的存储过程
参数的方式有三种:指定名称传递;按位置传递;混合方式传递
注意混合方式传递从使用【指定名称传递】的位置开始,后面的参数必须使用【指定名称传递】

 

create or replace procedure pro_in_par
( var_1 in nvarchar2,
  var_2 in number)   is
begin
update employees set salary=salary+var_2 where first_name=var_1;
commit;
dbms_output.put_line(var_1||'的工资已经增加了'||var_2||'!');
end pro_in_par;

结果:

 

begin
execute pro_in_par(var_1=>'Steven',var_2=>100);
end
匿名块已完成
Steven的工资已经增加了100!
begin
execute pro_in_par('Steven',var_2=>100);
end
匿名块已完成
Steven的工资已经增加了100!

pl/sql developer下的调用语法
begin
pro_in_par('Steven',100);
end
--举例混合参数输入,后面的参数没有使用【指定名称传递】
execute pro_in_par(var_1=>'Steven',100);
在行 42 上开始执行命令时出错:
execute pro_in_par(var_1=>'Steven',100)
错误报告:
ORA-06550: 第 1 行, 第 34 列: 
PLS-00312: 一个定位相关参数没有说明其相关性
ORA-06550: 第 1 行, 第 7 列: 
PL/SQL: Statement ignored
06550. 00000 -  "line %s, column %s:\n%s"
*Cause:    Usually a PL/SQL compilation error.
*Action:

观察存储过程中变量的使用(存储过程的输入输入参数,字符型不用定义长度,内部的字符型型变量是需要带长度的)

内部的变量不需要用declare,内部变量的定义在as之后,

 begin end 之前

--表准备
create table chl_simple(fid int,fname  varchar2(200));
--存储过程
create or replace procedure chl_ztablecreate01
(var_fname in varchar2)
as
var_sql varchar2(200);
begin
var_sql:=var_fname;
insert into chl_simple(fid,fname) values(1,var_sql);
end;
--存过程调用
begin
chl_ztablecreate01('12345');
end;

举例一个带out模式和in out模式参数存储过程

create procedure pro_out_par
( var_1 in out number,
  var_2 out employees.first_name%type,
  var_3 out employees.phone_number%type) is
begin
select first_name,phone_number into var_2,var_3 from employees where employee_id=var_1;
end pro_out_par;
--执行
declare 
ex_var_1 number;
ex_var_2  employees.first_name%type;
ex_var_3  employees.phone_number%type;
begin
ex_var_1:=102;
pro_out_par(ex_var_1,ex_var_2,ex_var_3);
dbms_output.put_line('员工号为'||ex_var_1||'的员工姓名是;'||ex_var_2||',联系电话是:'||ex_var_3);
end;

结果;

匿名块已完成
员工号为102的员工姓名是;Lex,联系电话是:515.123.4569

只有努力不会背叛
博文仅供参考,欢迎大家来访。如有错误之处,希望批评指正。

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/160929.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • centos7.4安装docker_docker打包python应用

    centos7.4安装docker_docker打包python应用前言当我们在一台电脑上搭建了python3.6的环境,下次换台电脑,又得重新搭建一次,设置环境变量等操作。好不容易安装好,一会提示pip不是内部或外部命令,一会又提示pip:commandno

  • SQLServer2K远程连接问题解决方案(转载自飞狐小屋)

    SQLServer2K远程连接问题解决方案(转载自飞狐小屋)由于特定需求,最近实验室需要远程连接外地的sqlserver2000服务器,最开始怎么连也连不上,出现了很多问题,但是在今天上午,借用实验室的测试条件(一个公网IP,两个教育网静态IP),终于调试通过,也算是完成了老师的任务,在这里写下自己的心得,参考了很多网上的文章和论坛里的问题,希望对有此需要的有帮助。不完善之处,也请留言。废话少说,进入主题。步骤:一看ping服务…

  • latex参考文献为网址「建议收藏」

    latex参考文献为网址「建议收藏」1、引入hyperref包:\usepackage{hyperref }2、举例:@misc{A:2005,  author = {AlexanderTotok},  title = {hello },  howpublished = {\url{http://cs.nyu.edu/totok/professional/software/tpcw/tpcw.html}}

  • pycharm 中文输入_pycharm中文输入法

    pycharm 中文输入_pycharm中文输入法1.Pycharm编译器中英文切换1.左上角打开file(文件)—>setting(设置)—plugins(插件)2.搜索chinese,点击安装3.安装完根据提示重启就行2.pycharm输入法不能输入中文1.找到pycharm的bin文件(我的是在/opt/pycharm/bin)2.打开pycharm.sh,在当前区域添加以下代码(我的是第144行)。如果是fcitx输入框架,则ibus换成fcitxexportLC_ALL=zh_CN.UTF-8expor

  • sql注入 报错注入_sql原理

    sql注入 报错注入_sql原理sql注入报错注入原理详解前言我相信很多小伙伴在玩sql注入报错注入时都会有一个疑问,为什么这么写就会报错?曾经我去查询的时候,也没有找到满意的答案,时隔几个月终于找到搞清楚原理,特此记录,也希望后来的小伙伴能够少走弯路0x01我们先来看一看现象,我这里有一个users表,里面有五条数据:然后用我们的报错语句查询一下:selectcount(*…

  • Onenote插件,云扩容

    Onenote插件,云扩容目录1.onenote2.插件3.云空间扩容4.onenote教程这些博主找了好久,现在一步到胃。特发布这篇文章,为后来的人指路。onenote各系列,公众号“软件管家”,有365,2016-2021系列,可正常同步。插件onetastic,直接官网免费onenoteclipper同onenotegem珍,有16版的,亲测可用于365版本。复制这段内容打开「百度网盘」APP即可获取链接:https://pan.baidu.com/s/1DtWmSRQ3cy1S6upA6DLU

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号