oracle function学习基层:

  函数就是一个有返回值的过程。

   首先 知道oracle 使用限制:

        函数调用限制: 1、 SQL语句中只能调用存储函数(服务器端),而不能调用客户端的函数

             2、SQL只能调用带有输入参数,不能带有输出,输入输出函数

             3、SQL不能使用PL/SQL的特有数据类型(boolean,table,record等)

            4、SQL语句中调用的函数不能包含INSERT,UPDATE和DELETE语句

  创建语法:

    create or replace function 函数名称(    argu1 [mode1] datatype1, --  定义参数变量)

     return datatype --    定义返回的数据类型

  is

       begin

      数据库操作

      Return 返回的数据变量

    end;

我举一例子:

定义一个函数:此函数可以根据雇员的编号查询出雇员的年薪
  CREATE OR REPLACE FUNCTION myfun(eno emp.empno%TYPE)

  RETURN NUMBER
  IS
    rsal NUMBER ;
  BEGIN
      SELECT (sal+nvl(comm,0))*12 INTO rsal FROM emp WHERE empno=eno ;
  RETURN rsal ;
  END ;

我理解的上面意思:

   我分几块解释上面的例子:    首先创建语句不用说了  创建一个function () 名字为 :myfun;

                   (参数类型名 eno  ,参数类型 emp.empno%TYPE)  [ emp.empno%TYPE] :意思是和这个表的这个字段类型相同 这样做 可以防止在操作时出现莫名错误,定这个参数的作用 和java 的作用差不多都是 为在我们实际调用时,把实参 传到function中

               RETURN NUMBER :  /* 定义返回的数据类型 */

                IS:

               rsal NUMBER ;   /*定义一个变量 名字 rsal ,类型为NUMBER ,这个变量作用 看下面即可 */

              BEGIN:  

                SELECT (sal+nvl(comm,0))*12 INTO rsal FROM emp WHERE empno=eno ;

                /*上面的语句 就是我真正函数的主体 ,也是我写函数执行的主要逻辑

                   大概解释下:查询 年薪【 (sal+nvl(comm,0))*12】 根据 员工的编号 ;nvl(comm,0) 这是个常用函                          数意思是 如果comm 为空,则用0 代替  ,

                   INTO rsal : 这个是 将我们查询的结果 放入变量

                */

               RETURN rsal ; 返回 变量

                 END ;

执行上面定义的function:

    SELECT myfun(7369) FROM dual ; /* 不做解释*/

在写几个例子加深理解:

      写一个函数 输入一个员工名字,判断该名字在员工表中是否存在。存在返回 1,不存在返回 0
        create or replace function empfun(en emp.ename%type) return number
          is
          is_exist number;
            begin
              select count(*) into is_exist from emp where ename=upper(en);
          return is_exist;
          end;
/
       1.写一个函数,传入员工编号,返回所在部门名称
        create or replace function myfun(eno emp.empno%type) return varchar
          is
          name varchar(30);
        begin
              select d.dname into name from emp e,dept d where e.deptno = d.deptno and e.empno = eno;
            return name;
        end;
/

     2.写一个函数,传入时间,返回入职时间比这个时间早的所有员工的平均工资
          create or replace function getAvgSal(hdate emp.hiredate%type) return number
           is
           esal number;
            begin
              select avg(sal) into esal from emp where hdate>emp.hiredate;
            return esal;
            end;

oracle function学习1的更多相关文章

  1. Asp.Net MVC4 + Oracle + EasyUI 学习 序章

    Asp.Net MVC4 + Oracle + EasyUI  序章 -- 新建微软实例 本文链接:http://www.cnblogs.com/likeli/p/4233387.html 1.  简 ...

  2. Oracle RAC学习笔记:基本概念及入门

    Oracle RAC学习笔记:基本概念及入门 2010年04月19日 10:39 来源:书童的博客 作者:书童 编辑:晓熊 [技术开发 技术文章]    oracle 10g real applica ...

  3. Oracle GoldenGate学习之Goldengate介绍

    Oracle GoldenGate学习之Goldengate介绍 (2012-10-02 17:07:27) 标签: 检查点 数据传输 队列 进程 分类: Goldengate Goldengate介 ...

  4. oracle 12c 学习系列(1)–12c初体验

    详见原文博客链接地址: oracle 12c 学习系列(1)–12c初体验

  5. Oracle RAC学习笔记01-集群理论

    Oracle RAC学习笔记01-集群理论 1.集群相关理论概述 2.Oracle Clusterware 3.Oracle RAC 原理 写在前面: 最近一直在看张晓明的大话Oracle RAC,真 ...

  6. Oracle RAC学习笔记02-RAC维护工具集

    Oracle RAC学习笔记02-RAC维护工具集 RAC维护工具集 1.节点层 2.网络层 3.集群层 4.应用层 本文实验环境: 10.2.0.5 Clusterware + RAC 11.2.0 ...

  7. Python Built-in Function 学习笔记

    Python Built-in Function 学习笔记 1. 匿名函数 1.1 什么是匿名函数 python允许使用lambda来创建一个匿名函数,匿名是因为他不需要以标准的方式来声明,比如def ...

  8. [Oracle]OWI学习笔记--001

    [Oracle]OWI学习笔记--001 在 OWI 的概念里面,最为重要的是 等待事件 和 等待时间. 等待事件发生时,需要通过 P1,P2,P3 查看具体的资源. 可以通过 v$session_w ...

  9. 推荐一个Oracle数据库学习网站

    推荐一个我个人的Oracle数据库学习网站,比较系统性的整理,会持续更新的网站.网址: Oracle基础教程: http://www.oraclejsq.com/article/010100110.h ...

随机推荐

  1. php计算网段内所有IP,分配子网段

    由于最近业务需要,写了个获取网段内所有IP的函数,以及分配可用子网段的函数 /** * 根据网段获取计算所有IP * @param string $segment 网段 '139.217.0.1/24 ...

  2. Excel 2016在大数据分析领域有了很多的改善

    Excel 2016在大数据分析领域有了很多的改善 通常,我们会把大数据分析的整个过程分为五个阶段: 获取获取,数据分析,可视化,发布报告,应用报告. 在获取数据方面,Excel 2016相对Exce ...

  3. PHP面向对象魔术方法之__get 和 __set函数

    l 基本的介绍 (1) 当我们去使用不可以访问的属性时,系统就会调用__get方法. (2) 不可以访问的属性指的是(1 . 该属性不存在 2. 直接访问了protected或者private属性) ...

  4. 解决编译GCC内存不足的错误

    近期在使用阿里和腾讯的云服务器,由于只是测试用所以只租用了廉价512的内存,在编译gcc时遇到错误,表面上看只是编译错误,并且原因不明,纠结了几次之后猜测应该是由于系统资源不足导致的,所以尝试增加系统 ...

  5. IO流11 --- 缓冲流(字符型)实现文本文件的复制 --- 技术搬运工(尚硅谷)

    方法一:读到指定字符数组 @Test public void test7(){ BufferedReader br = null; BufferedWriter bw = null; try { br ...

  6. 2019-9-11-完整的-P2P-应用需要包含哪些功能

    title author date CreateTime categories 完整的 P2P 应用需要包含哪些功能 lindexi 2019-9-11 9:0:55 +0800 2019-09-05 ...

  7. Leetcode60. Permutation Sequence第k个排列

    给出集合 [1,2,3,-,n],其所有元素共有 n! 种排列. 按大小顺序列出所有排列情况,并一一标记,当 n = 3 时, 所有排列如下: "123" "132&qu ...

  8. Windows API 第17篇 GetLogicalDriveStrings 获取本机所有逻辑驱动器,以根目录的形式表示

    函数原型:DWORD GetLogicalDriveStrings(  DWORD nBufferLength,  // size of buffer                          ...

  9. C#(.net)中的DllImport

    大家在实际工作学习C#的时候,可能会问:为什么我们要为一些已经存在的功能(比如Windows中的一些功能,C++中已经编写好的一些方法)要重新编写代码,C#有没有方法可以直接都用这些原本已经存在的功能 ...

  10. 留下来做项目经理还是跳槽学Java

    毕业两年了,曾经给自己计划工作两年后跳一次槽,去尝试学习更多的东西.2012年7月5日入职,现在整整两年,最近面临这样的一个抉择:是留在公司继续做项目经理,还是跳槽去学习Java. 我的基本情况:本科 ...