#存储过程:封装在服务器上一段sql片段,已经编译好了的代码。

1.客户端调存储过程,执行效率就会非常高效。

语法:

create [or replace] procedure 存储过程名称

           (参数名  in|out 参数类型,参数名  in|out 参数类型)is  |  as

- - 声明部分

begin

- - 业务逻辑

end;

例子:

/*需求:给指定员工涨薪,并打印涨薪前后的工资

参数:in员工编号(用来接受输入) in 涨多少

声明一个变量:存储涨工资前的工资(因为不确定,所以用变量)  打印涨薪前的工资  更新工资

打印涨薪后的工资

*/

create or replace procedure pro_updatesal(vempno in number, vnum in number)

is

- -声明变量,记录当前工资

vsal number;

begin

    - -查询当前工资

         select sal into vsal from emp

         where empno=vempno;

    - -输出涨薪前的工资

         dbms_output.put_line(“涨薪前:”||vsal);

    - -更新工资

         update emp set sal=vsal+vnum

         where empno=vempno;

     - -输出涨薪后的工资

         dbms_output.put_line(“涨薪后:”||(vsal+vnum);

     - -提交事务

          commit;

end;

调用:

方法一:

- -在右边的小窗口中找到一个procedures,并在其中点相应文件点右键,单击view看错误提示。再选中再执行。

call proc_updatesal(7788,10);

- -再选中再执行。并在out中可以看到内容。

方法二:

begin

      call proc_updatesal(7788,-100);

end;

说明:7788是员工编号。

----------------------------------------------------------------------------------------

----------------------------------------------------------------------------------------

#存储函数:封装在oracle在服务器里面的plsql片段,

它是已经编译好的代码片段。

语法:

create [for replace] function 存储函数的名称(参数名 in|out 参数类型,参数名 in|out 参数类型)

return 参数类型

is | as

begin

end;

/*存储过程和函数的区别:

1.它们本质上没有区别

2.函数存在的意义是给过程调用 /*存储过程中调用存储函数*/

3.函数的返回类型在is | as上面定义

4.函数可以在sql里面直接调用

*/

例子:默认用in

/*查询指定员工的年薪

参数:员工的编号

返回:年薪

*/

create or replace function

 func_getsal(vempno number)

 return number

is

 - -声明变量,保存年薪

      vtotalsal number;

begin

          select sal*2+nul(comm,0) into vtotalsal

          from emp

          where empno=vempno; 

          return vtotalsal;

end; 

说明:into vtotalsal是表示赋值给 into vtotalsal,也就是年薪,并最后将年薪返回过来。

再然后选中并运行,然后可以看到左侧function中有对应的函数名,可以用view

查看是否有错误。

- -调用存储函数

declare

     vsal number;

begin

     vsal=func_getsal(7788); 

     dbms_output.put_line(); 

- -这里要有一个返回值

- -所以要声明一个返回值

end;

- -最后可以在output中看到结果。

- -函数可以在sql里面直接调用

select ename,func_getsal(empno)

from emp;

—存储过程

create or replace procedure proc_gettotalsal

(empmno in number,vtotalsal out number)

is

begin

      select sal*12+nvl(comm,0) into vtotalsal

      from emp

      where empno=vempno;

end;

declare

begin

       pro_gettotalsal(7788,vtotal);

       dbms_output.put_line(“年薪:”|| vtotal);

end;

----------------------------------------------------------------------------------------

说明:重复出变化,把同一东西做三次,好过把十个东西做一次。

----------------------------------------------------------------------------------------

#OracleNVL函数用法

从两个表达式返回一个非 null 值。

语法

  NVL(eExpression1, eExpression2)

参数

 eExpression1, eExpression2

如果 eExpression1 的计算结果为 null 值,则 NVL( ) 返回 eExpression2。如果 eExpression1 的计算结果不是 null 值,则返回 eExpression1。

eExpression1 和 eExpression2 可以是任意一种数据类型。如果 eExpression1 与 eExpression2 的结果皆为 null 值,则 NVL( ) 返回 .NULL.。

----------------------------------------------------------------------------------------

oracle之存储过程和存储函数的使用和区别的更多相关文章

  1. 编程开发之--Oracle数据库--存储过程和存储函数(2)

    上一小结我们简单介绍了存储过程和存储函数,对存储过程和存储函数有了一个基本的了解,接下来介绍在java程序中如何调用我们创建的存储过程和存储函数 1.在应用程序中调用我们的存储过程 创建一个简单的Ja ...

  2. 编程开发之--Oracle数据库--存储过程和存储函数(1)

    1.存储过程和存储函数 描述:指存储在数据库中供所有用户程序调用的子程序叫做存储过程.存储函数 区别:存储函数可以通过return子句返回一个函数的值 (1)存储过程 语法:create [or re ...

  3. Oracle数据库---存储过程、存储函数

    --创建存储过程CREATE OR REPLACE PROCEDURE first_procISBEGIN DBMS_OUTPUT.PUT_LINE('我是过程'); DBMS_OUTPUT.PUT_ ...

  4. Oracle03——游标、异常、存储过程、存储函数、触发器和Java代码访问Oracle对象

    作者: kent鹏 转载请注明出处: http://www.cnblogs.com/xieyupeng/p/7476717.html 1.游标(光标)Cursor 在写java程序中有集合的概念,那么 ...

  5. oracle存储过程和存储函数&触发器

    oracle存储过程和存储函数 指存储在数据库中供所有用户程序调用的子程序叫存储过程,存储函数 存储过程和存储函数的相同点:完成特定功能的程序 存储过程和存储函数的区别:是否用return语句返回值 ...

  6. oracle存储过程和存储函数

    存储过程 1.存储过程简介 下面先来简单介绍一下oracle的存储过程的语法,如下: create or replace procedure Tony_Process ( num in number, ...

  7. Oracle 存储过程以及存储函数

    以下的一些例子是基于scott用户下的emp表的数据,一和二使用的均为in,out参数,最后一个综合练习使用了 in out参数 一.存储过程 1.创建无参的存储过程示例  ------ hello ...

  8. 存储过程,存储函数(Oracle)

    存储过程和存储函数 指存储在数据库中供所有用户程序调用的子程序叫存储过程.存储函数. 存储过程和存储函数的区别? 存储函数:可以通过return 语句返回函数值. 存储过程:不能 除此之外我们可以认为 ...

  9. day70-oracle 12-Java调用存储过程和存储函数

    我们现在调用的是存储过程和存储函数.用CallableSatement调用存储函数和存储过程. RDBMS:关系数据库.使用标准方式调用存储过程.也就是说:在mysql中调用和在oracle中调用的写 ...

随机推荐

  1. struct模块

    struct模块的作用是将数据长度转换成固定长度的内容 一般默认是4个字节 需要注意的是,struct模块是有缺点的,就是struct的int类型或别的类型不是无限制的.当整数大于一定值后,会失败,即 ...

  2. Android使用SpannableString设置多样式文本

    Android将一行文本设置为多种样式时,可以使用 SpannableString 来实现 private void setTips(){ String big = "大字深色"; ...

  3. 用于模型选择的AIC与BIC

    一.AIC(Akaike information Criterion)准则 二.BIC(Bayesian information Criterion)准则 参考文献: [1]AIC与BIC区别

  4. 查看Andorid应用是32位还是64位

    adb shell cat /proc/进程pid/maps 查看linker位数即可

  5. .NET Core使用Quartz执行调度任务进阶(转)

    一.前言运用场景 Quartz.Net是一个强大.开源.轻量的作业调度框架,在平时的项目开发当中也会时不时的需要运用到定时调度方面的功能,例如每日凌晨需要统计前一天的数据,又或者每月初需要统计上月的数 ...

  6. HTML5 缓存

    一.在html/htm文件中声明缓存,声明方式: <!DOCTYPE HTML> <html manifest="demo.appcache">...3 & ...

  7. mysql小脚本

    常用脚本 1)备份数据库 #!/bin/bash#每周一全量备份数据库 #DB1mysqldump -hip eduyun -u用户 -p密码 >eduyun`date +%Y-%m-%d-%H ...

  8. iframe中父页面与子页面的传值方法

    涉及到iframe传值的情况有这么几种:(1)父页面给iframe中的子页面传值(2)子页面调用父页面中的函数(3)iframe中的子页面给父页面传值(4)兄弟iframe之间的传值 下面来逐一看一下 ...

  9. Mysql8.0.11安装以及注意事项

    一.环境配置 首先在官网下载最新的mysql8.0.11数据库,解压到你需要放置的盘符最好不要有中文,然后新建MYSQL_HOME,参数为mysql解压后安装文件的bin文件路径如我的:变量名:MYS ...

  10. 数据库所有者 (dbo)

    数据库所有者 (dbo) dbo 是具有在数据库中执行所有活动的暗示性权限的用户.将固定服务器角色 sysadmin 的任何成员都映射到每个数据库内称为 dbo 的一个特殊用户上.另外,由固定服务器角 ...