PL/SQL子程序 它包含了函数和过程。此功能是指用户定义的函数。和系统功能是不同的。子程序通常完成特定的功能PL/SQL座。,能够被不同的应用程序多次调用。Oracle提供能够把PL/SQL程序存储在数据库中,并能够再不论什么地方来执行它。

这样就叫做存储过程或者是函数。

过程和函数的唯一差别就是函数总是向调用者返回数据。而过程则不返回数据。

函数

假设用户要常常运行某些操作,而且须要返回特定的数据。那么就能够将这些操作构造成一个函数。

能够使用SQL语句定义函数。

基本的语法:

create or replace function fun_name(argument [in | out | in out ]datatype  ...)

return datatype 

is | as

       -- 须要定义的变量 。记录类型 。 游标

begin

       --函数的运行体

exception

       --处理出现的异常

end ;

当中,return datatype , 是要返回数据的类型。IN參数标记表示传递给函数的值在函数运行中不改变;OUT标记表示一个值在函数进行计算并通过该參数传递给调用语句;IN OUT 标记表示传递给函数的值能够变化并传递给调用语句。

例:定义一个返回hello 的函数

create or replace function hello

return varchar2 

is

begin

       return 'Hello World';

end ;

运行 ,Function created ,函数创建成功。

函数的调用。与Oracle内置函数的调用同样,能够使用select hello from dual ;进行调用,也能够使用PL/SQL语句进行调用 :

begin

dbms_output.put_line(hello);

end ;

例:创建带參数的helloworld函数

create or replace function helloworld(str varchar2)

return varchar2

is

begin

       return 'Hello' || '_' ||str ;

end ;

函数的调用要在函数名称后面加上參数,即:select helloworld('World') from dual ;使用Pl/sql的调用除了加上參数外与上面同样,不在赘述。

例:求一个部门中,员工的工资总数的函数

create or replace function get_sal(dept number)

return number 

is

       v_sum number(10) := 0 ;

       cursor sal_cursor is select sal from emp where deptno = dept ;

begin 

       for c in sal_cursor loop

           v_sum := v_sum + c.sal ;

       end loop ;

       return v_sum ;

end ;

存储过程

存储过程,能够被多个应用程序调用。也能够向存储过程传递參数。向存储过程传回參数。

基本的语法

create or replace procedure pro_name(argument [in | out | in out ]datatype  ...) 

is | as

       -- 须要定义的变量 ,记录类型 , 游标

begin

       --函数的运行体

exception

       --处理出现的异常

end ;

例:使用存储过程。求部门的工资总和

create or replace procedure get_sal1(dept number ,sumsal out  number)

is

       cursor sal_cursor is select sal from emp where deptno = dept ;

begin 

       sumsal := 0 ;

       for c in sal_cursor loop

           sumsal := sumsal + c.sal ;

       end loop ;

       dbms_output.put_line(sumsal);

end ;

存储过程的调用:

declare 

  v_sum number(10) := 0 ;

begin 

  get_sal1(30 , v_sum);

end ;

调用格式:

CALL | EXCEUTE procedure_name(arg_list) ;

能够使用show error 命令来提示源代码的错误位置。

使用user_error 数据字典来查看各存储过程的错误位置。

删除过程和函数

删除过程

语法例如以下:

DROP PROCEDURE[USER.]procedure_name ;

删除函数

语法例如以下:

DROP FUNCTION [USER.]function_name ;

版权声明:本文博主原创文章。博客,未经同意不得转载。

Oracle 学习笔记 18 -- 存储函数和存储过程(PL/SQL子程序)的更多相关文章

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

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

  2. Oracle 学习笔记 19 -- 触发器和包浅析(PL/SQL)

    触发器是存放在数据库中的一种特殊类型的子程序.不能被用户直接调用,而是当特定事件或操作发生时由系统自己主动 调用执行.触发器不能接受參数.所以执行触发器就叫做触发或点火.Oracle事件指的是数据库的 ...

  3. Oracle 学习笔记(Windows 环境下安装 + PL/SQL)

    Oracle 安装.PL/SQL 配置使用  前言:因更换机械硬盘为 SSD 固态硬盘装了新 Windows 7 系统,需要重新搭建开发环境,把 Oracle 安装过程和 PL/SQL 配置使用做下笔 ...

  4. Oracle学习笔记:trunc函数

    在Oracle中可以使用trunc函数进行日期截取和数字截取,具体使用方法如下: 1.trunc(for dates) 日期截取 语法:trunc(date,[fmt]) select trunc(s ...

  5. Oracle学习笔记:wm_concat函数合并字段

    在Oracle中使用wm_concat(column)可以实现字段的分组合并,逗号分隔. 例如,现有表temp_cwh_test: -- 创建临时表 create table temp_cwh_tes ...

  6. Oracle学习笔记_03_单行函数

    1.SQL函数: 单行函数.多行函数 单行函数:       操作数据对象       接受参数返回一个结果       只对一行进行变换       每行返回一个结果       可以转换数据类型  ...

  7. Oracle学习笔记之用户自定义函数

    自定义函数语法格式:   用户自定义的函数,可以直接在sql语句中直接调用,并且任何一个funciton都必须有返回值,而且该函数声明后,是保存在数据端的,我们随时可以使用:注意:函数只能有一个返回值 ...

  8. Oracle学习笔记:decode函数

    decode函数主要作用:将查询结果翻译成其他值(即以其他形式变现出来) 使用方法: SELECT DECODE(colunm_name,值1,翻译值1,值2,翻译值2……值n,翻译值n,缺省值) F ...

  9. Oracle学习笔记_05_分组函数

    组函数:avg  sum  max  min   count group by having group by 增强:rollup      cube     grouping      groupi ...

随机推荐

  1. 【SPOJ 694】Distinct Substrings (更直接的求法)

    [链接]h在这里写链接 [题意] 接上一篇文章 [题解] 一个字符串所有不同的子串的个数=∑(len-sa[i]-height[i]) [错的次数] 0 [反思] 在这了写反思 [代码] #inclu ...

  2. UIActionSheet上加入UIPickerView iOS8替换方案

    此套替换方案採用"UIView+动画"方式实现(将UIActionSheet替换为UIView) 界面层级例如以下: 第一层:view(这一层充满整个屏幕,初始化时颜色为透明.us ...

  3. Android Studio2.0 Beta 2版本号更新说明及注意事项

    我们刚刚向canary channel推送了Android Studio2.0 Beta 2版本号 老毕译注: ---------- canary channel: 金丝雀版本号,平均1到2周就会更新 ...

  4. Canvas基础知识总结之中的一个

    canvas的HTML语法: <canvas> Canvas not supported </canvas> 上面这句代码中内容部分所含的文本,这种文本的叫法"后备内 ...

  5. c#编程:给定一个正整数求出是几位数并逆序输出

    <span style="color:#FF0000;">第一步:把输入的数字转为字符串n.ToString() 第二步:求出字符串的长度即为正整数的位数 第三步:从后 ...

  6. HTTP请求头与响应头

    http://m.blog.csdn.net/article/details?id=48918857 本篇文章中,将学习一下HTTP请求头与响应头的知识. 一.HTTP头引入: 正确的设置HTTP头部 ...

  7. SpringMVC上传图片总结(1)---常规方法进行图片上传,使用了MultipartFile、MultipartHttpServletRequest

    原文地址:https://blog.csdn.net/chenchunlin526/article/details/70945877 SpringMVC上传图片总结(1)---常规方法进行图片上传,使 ...

  8. 终端中经常使用的shell 命令

    Mac 在shell命令终端中,Ctrl+n相当于方向向下的方向键,Ctrl+p相当于方向向上的方向键. 在命令终端中通过它们或者方向键能够实现对历史命令的高速查找.这也是高速输入命令的技巧. 在命令 ...

  9. Android多线程研究(9)——线程锁Lock

    在前面我们在解决线程同步问题的时候使用了synchronized关键字,今天我们来看看Java 5.0以后提供的线程锁Lock. Lock接口的实现类提供了比使用synchronized关键字更加灵活 ...

  10. crx

    https://www.crx4chrome.com/down/770/crx/ Downloading crx file for Linkclump The Linkclump crx file y ...