Oracle Procedure记录
admin
2023-04-20 21:22:47
0

1、定义
所谓存储过程(Procedure),就是一组用于完成特定数据库功能的SQL语句集,该SQL语句集经过
编译后存储在数据库系统中。在使用时候,用户通过指定已经定义的存储过程名字并给出相应的存储过程参数
来调用并执行它,从而完成一个或一系列的数据库操作。
2、存储过程的创建
Oracle存储过程包含三部分:过程声明,执行过程部分,存储过程异常。
3. 使用存储过程的好处:
1.简化复杂的操作
2.增加数据的独立性
3.提高安全性
4.存储过程的语法
CREATE [OR REPLACE] PROCEDURE procedure_name [in | out | in out datatype]
IS|AS
<声明部分>
begin
<执行部分>
exception
<异常部分>
end;
4.1无参数的存储过程:

create or replace procedure p_test1 as
begin
for i in (select slbh,bdczh from dj_djb where slbh like '20170825%') loop
dbms_output.enable(buffer_size=>null);
dbms_output.put_line(i.slbh||','||i.bdczh);
end loop;
end;

begin
p_test1;
end;
4.2.有参的存储过程:
4.2.1.参数名 IN 数据类型 DEFAULT 值;
定义一个输入参数变量,用于传递参数给存储过程。在调用存储过程时,主程序的实际参数可以是常量、有值变量或表达式等。DEFAULT 关键字为可选项,用来设定参数的默认值。如果在调用存储过程时不指明参数,则参数变量取默认值。在存储过程中,输入变量接收主程序传递的值,但不能对其进行赋值。
ege:

create or replace procedure p_test2 (v_slbh in  varchar2 default 201711010025 )
as
v_bdczh dj_djb.bdczh%type;
begin
  select bdczh into v_bdczh from dj_djb where slbh =v_slbh;
  dbms_output.put_line(v_bdczh);
  end;

4.2.2.参数名 OUT 数据类型;
定义一个输出参数变量,用于从存储过程获取数据,即变量从存储过程中返回值给主程序。
在调用存储过程时,主程序的实际参数只能是一个变量,而不能是常量或表达式。在存储过程中,参数变量只能被赋值而不能将其用于赋值,在存储过程中必须给输出变量至少赋值一次。
ege:

create or replace procedure p_test3 (v_slbh varchar2 default 201711010025,v_bdczh out varchar2)
as
begin
  select bdczh into v_bdczh from dj_djb where slbh=v_slbh;
  dbms_output.put_line(v_slbh||','||v_bdczh);
  end ;
  ....调用.......
  declare
  v_1 dj_djb.bdczh%type;
   begin
    p_test3(v_bdczh=>v_1);
    end;

4.2.3.参数名 IN OUT 数据类型 DEFAULT 值;
定义一个输入、输出参数变量,兼有以上两者的功能。在调用存储过程时,主程序的实际参数只能是一个变量,而不能是常量或表达式。DEFAULT 关键字为可选项,用来设定参数的默认值。在存储过程中,变量接收主程序传递的值,同时可以参加赋值运算,也可以对其进行赋值。在存储过程中必须给变量至少赋值一次。
注:如果省略IN、OUT或IN OUT,则默认模式是IN。
5.查看存储过程错误原因:
select * from user_errors where name=upper(‘p_test1’);

                                                                                                   by wolihaito 2018.03.26

相关内容

热门资讯

燃气发电与电池储能相结合,成为... 来源:市场资讯 (来源:i商周) 孟菲斯一座xAI数据中心的燃气轮机 人工智能的用电飙升,让数据中心...
景嘉微:JM11性能大幅提升,... 有投资者在互动平台向景嘉微提问:“董秘您好!关注到近期有用户反馈公司JM11显卡推出了适配windo...
原创 v... 影像的发展进一步推动,不少品牌推出了专业影像手机,拥有2亿像素摄像头、色彩还原摄像头、影像芯片、影像...
荣耀首款自研耳夹式耳机官宣即将... 快科技5月13日消息,日前,荣耀首席营销官关海涛宣布,荣耀全场景团队自研首款耳夹式耳机马上上市,并称...
谷歌推出Googlebooks... IT之家 5 月 13 日消息,2026 年 I/O 开发者大会下周(5 月 19~20 日)召开之...
自控所推动GNC专业智能化升级 来源:滚动播报 (来源:中国航空报) 本报讯 5月6日,航空工业自控所召开 GNC+AI关键技术研发...
华电电力申请数据库访问方法专利... 国家知识产权局信息显示,华电电力科学研究院有限公司申请一项名为“数据库访问方法、装置、设备及介质”的...
苏州率先打造数据流通利用新范式 数据,作为第五大生产要素 具有流动性强、非消耗性、非均质性等特点 苏州率先打造数据流通利用新范式 夯...
伊媒披露伊美新一轮谈判5个先决... 当地时间5月12日,据伊朗法尔斯通讯社援引知情人士消息报道,伊朗对与美国新一轮谈判提出的5个先决条件...
英国将向霍尔木兹海峡多国护航行... 当地时间12日,总台记者从英国国防部获悉,英国将向在霍尔木兹海峡执行任务的多国护航行动提供无人机、战...