创建时定义名称 2、可以被Oracle server 保存 3、可以被任何程序调用 4、可以被共享

存储过程:

1、不带参数的存储过程:

SQL> create or replace procedure proc1 is
2
3 v_ename emp.ename%type;
4 v_sal emp.sal%type ;
5
6 begin
7 select ename,sal into v_ename,v_sal from emp where empno=&no;
8 dbms_output.put_line('Name is : '||v_ename||' , '||'Salary is : '||v_sal);
9 exception
10 when no_data_found then
11 dbms_output.put_line('you number is not crrect ,please input again !');
12 when others then
13 dbms_output.put_line('Others error !');
14 end;
SQL> exec proc1;         //执行存储过程
SQL> create or replace procedure proc1 is
2
3 v_ename emp.ename%type;
4 v_sal emp.sal%type ;
5
6 begin
7 select ename,sal into v_ename,v_sal from emp where empno=&no;
8 dbms_output.put_line('Name is : '||v_ename||' , '||'Salary is : '||v_sal);
9 exception
10 when no_data_found then
11 dbms_output.put_line('you number is not crrect ,please input again !');
12 when others then
13 dbms_output.put_line('Others error !');
14 end;

通过数据字典查看procedure信息:

带有参数的存储过程: 参数定义中,IN、OUT和IN OUT代表参数的三种不同模式:

IN:当调用存储过程时,该模式的形参接收对应实参的值,并且该是只读的,即不能被修改。默认为IN。   OUT:该形参被认为只能写,既只能为其赋值。在存储过程中不能读它的值。返回时,将该形参值传给相应的实参。

IN OUT:都允许

①in

SQL> create or replace procedure ins_dept
2 (v_deptno in number,v_dname varchar2, v_loc in varchar2) is
3
4 e_dept_err exception;
5 pragma exception_init(e_dept_err ,-0001);
6 begin
7 insert into dept values (v_deptno,v_dname,v_loc);
8 commit;
9 exception
10 when e_dept_err then
11 dbms_output.put_line('You deptno is not unique ,Please input unique deptno number !');
12 when others then
13 dbms_output.put_line('Others error !');
14 end;

②OUT:

SQL> create or replace procedure proc2
2 ( v_empno in number ,v_ename out varchar2,v_sal out number)
3 is
4
5 begin
6
7 select ename,sal into v_ename,v_sal from emp where empno=v_empno;
8
9 dbms_output.put_line ('Employee name is: '||v_ename);
10
11 dbms_output.put_line ('Employee salary is: '||v_sal);
12 exception
13 when no_data_found then
14 dbms_output.put_line('Employee ID is error !');
15 when others then
16 dbms_output.put_line('Others error !');
17 end;
在系统下运行:
SQL> var name varchar2(10);
SQL> var sal number;
SQL> exec proc2(7369,:name,:sal);
PL/SQL procedure successfully completed
name
---------
SMITH
sal
---------
6800 通过PLSQL 块运行:
SQL> declare
2 v_name emp.ename%type;
3 v_sal emp.sal%type;
4 begin
5 proc2(7369,v_name,v_sal);
6 end;

3.IN-OUT:

SQL> create or replace procedure proc3
2 (v_empno in out number ,v_ename out varchar2,v_sal out number)
3 as
4 begin
5 select empno,ename,sal into v_empno,v_ename,v_sal from emp where empno=v_empno;
6 dbms_output.put_line ('Employee ID is: '||v_empno);
7 dbms_output.put_line ('Employee name is: '||v_ename);
8 dbms_output.put_line ('Employee salary is: '||v_sal);
9 exception
10 when no_data_found then
11 dbms_output.put_line('Employee ID is error !');
12 when others then
13 dbms_output.put_line('Others error !');
14 end;
15 /
Procedure created 执行存储过程: SQL> declare
2 v_empno emp.empno%type;
3 v_ename emp.ename%type;
4 v_sal emp.sal%type;
5
6 begin
7 v_empno := &n;
8 proc3(v_empno,v_ename,v_sal);
9
10 end;

【PL/SQL练习】命名块: 存储过程、函数、触发器、包的更多相关文章

  1. 【PL/SQL】匿名块、存储过程、函数、触发器

    名词解释 子程序:PL/SQL的过程和函数统称为子程序. 匿名块:以DECLARE或BEGIN开始,每次提交都被编译.匿名块因为没有名称,所以不能在数据库中存储并且不能直接从其他PL/SQL块中调用. ...

  2. 查看SQL SERVER 加密存储过程,函数,触发器,视图

    原文:查看SQL SERVER 加密存储过程,函数,触发器,视图 create  PROCEDURE sp_decrypt(@objectname varchar(50))ASbeginset noc ...

  3. oracle pl/sql简介、块、过程

    pl/sql语言是oracle在sql上扩展的语言.1 过程.函数.触发器是在pl/sql编写2 过程.函数.触发器是在oracle中3 pl/sql的语句可以在java中直接调用 简单介绍 在sql ...

  4. 在PL/SQL中调用Oracle存储过程

    存储过程 1 什么是存储过程? 用于在数据库中完成特定的操作或者任务.是一个PLSQL程序块,可以永久的保存在数据库中以供其他程序调用. 2 存储过程的参数模式 存储过程的参数特性: IN类型的参数 ...

  5. 使用oracle 的 PL/Sql 定时执行一个存储过程

    CSDN日报20170322--<关于软件研发的一些体会总结> 同步博客至 CSDN ,让更多开发者看到你的文章 看微博技术大咖解析互联网应用架构实战 使用oracle 的 PL/Sql ...

  6. pl/sql developer中dbms_output.put_line函数的运用

    pl/sql developer中dbms_output.put_line函数可以打印想显示在屏幕上的信息,运用时需要注意几点: 1 必须处于begin   ...  end: 2 需要先执行 set ...

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

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

  8. PL/SQL规范、块、过程、函数、包、触发器

    1.pl/sql规范 标识符号的命名规范 1) 定义变量,用 v- 作为前缀 v-sal 2)定义常亮, 用 c- 作为前缀 c-rate 3) 定义游标,用 cursor作为后缀 emp_curso ...

  9. PL/SQL学习笔记_03_存储函数与存储过程

    ORACLE 提供可以把 PL/SQL 程序存储在数据库中,并可以在任何地方来运行它.这样就叫存储过程或函数. 存储函数:有返回值,创建完成后,通过select function() from dua ...

  10. oracle 之索引,同义词 ,关键词,视图 ,存储过程,函数,触发器

    --创建索引 关键词 index create[unique] index index_name on table_name(column_name [,column_name…]) [tablesp ...

随机推荐

  1. Python列表,元组,字典,序列,引用

    1.列表 # Filename: using_list.py # This is my shopping list shoplist=["apple", "mango&q ...

  2. 战胜忧虑<5>——运用亚里士多德法则

    运用亚里士多德法则 如果人们将忧虑的时间,用来寻找解决问题的答案,那忧虑就会在人们智慧的光芒下消失.那么当你面对忧虑时,应该怎么办理?答案是,我们一定要学会用下面三种分析问题的基本步骤来解决各种不同的 ...

  3. usb由于其配置信息(注册表中的)不完整或已损坏,Windows 无法启动这个硬件设备

    在设备管理器的usb设备的属性中,显示提示“由于其配置信息(注册表中的)不完整或已损坏,Windows 无法启动这个硬件设备”.注册表坏了.经过查询,解决方法如下: 方法:打开注册表编辑器(开始--& ...

  4. (C#) Action, Func, Predicate 等泛型委托

    (转载网络文章) (1). delegate delegate我们常用到的一种声明   Delegate至少0个参数,至多32个参数,可以无返回值,也可以指定返回值类型.   例:public del ...

  5. PL/SQL中批量执行SQL脚本(不可把所有的语句都复制到New SQL Windows)

    PL/SQL中批量执行SQL脚本,不可把所有的语句都复制到New SQL Window,因为这样会导致缓冲区过大而进程卡死! 最好的办法是将要执行的SQL脚本存放到指定文件中,如C:\insert.s ...

  6. canvas刮刮乐

    这周有点迷茫,不知道干嘛了,一天天就过去了!我在博客右侧公告栏加了qq交流,各位有好的主题,或者有趣的技术,欢迎交流!今天突发奇想,就写了2个h5 canvas的demo玩玩! demo一:刮刮乐 舍 ...

  7. 执行sh文件 进行MongoDB的业务逻辑导入

    将从HDFS中的数据转化为Json格式写入文件后,十个文件的文件名为 文件名_01 ...._02 ....03格式. 编写个简单的sh文件 通过for do循环让i+1 文件名对应上就可以的- -执 ...

  8. [物理学与PDEs]第5章 弹性力学

    [物理学与PDEs]第5章第1节 引言 [物理学与PDEs]第5章第2节 变形的描述, 应变张量 2.1 变形梯度张量 [物理学与PDEs]第5章第2节 变形的描述, 应变张量 2.2 Cauchy ...

  9. C语言中,数组名作为参数传递给函数时,退化为指针

    C语言中,数组名作为参数传递给函数时,退化为指针   C语言中,数组名作为参数传递给函数时,退化为指针:需要数组大小时, 需要一个参数传数组名,另一个传数组大小. 数组名做函数参数时,就相当于指针了. ...

  10. Perl中文/unicode/utf8/GB2312之间的转换

    参考:http://daimajishu.iteye.com/blog/959239不过具测试,也有错误:原文如下: # author: jiangyujieuse utf8;  ##在最后一个例子, ...