• 系统内置函数
    1. 数学运算函数
    2. 字符串函数
    3. 统计函数
    4. 日期函数
  • 用户定义函数:存储在数据库中的代码块,可以把值返回到调用程序。调用时如同系统函数一样
    • 参数模式
      1. IN模式:表示该参数时输入给函数的参数
      2. OUT模式:表示该参数在函数中被赋值,可以传给函数调用程序
      3. IN OUT模式:表示该参数既可以传值也可以被赋值
    • 创建函数
      1.  CREATE[OR REPLACE]FOUNCTION<函数名>
        (
        <参数名1>,<参数类型><数据类型>,
        <参数名2>,<参数类型><数据类型>,
        <参数名3>,<参数类型><数据类型>,
        ...
        )
        RETURN<返回值类型> /*定义返回值类型*/
        {IS|AS}
        [声明变量]
        BEGIN
        <函数体>
        [RETURN(<返回表达式>);]
        END[<函数名>];
         CREATE OR REPLACE FUNCTION 函数名称
        (
        in_pmt IN char,
        out_pmt OUT char,
        in_out_pmt IN OUT char
        )
        RETURN char
        AS
        return_char char;
        BEGIN
        <函数语句序列>
        RETURN(return_char);
        END[函数名称];
         CREATE OR REPLACE FUNCTION average(cnum IN char)
        RETURN number
        AS
        avger number;
        BEGIN
        SELECT AVG(成绩)INTO avger
        FROM CJB
        WHERE 课程号=cnum
        GROUP BY 课程号;
        RETURN(avger);
        END;
      2. 语法要求
         函数语句序列中可能出现的情况
        IN模式:传递参数 对应变量为右值
        OUT模式:在函数中被赋值 对应变量为左值
      3. 调用函数
         CREATE OR REPLACE FUNCTION count_num(in_sex IN)
        RETURN number
        AS
        out_num number;
        BEGIN
        IF in_sex='男'THEN
        SELECT COUNT(性别)INTO out_num;
        FROM XSB WHERE 性别=‘男';
        ELSE
        SELECT COUNT(性别)INTO out_num;
        FROM XSB WHERE 性别=‘女';
        END IF
        RETURN(out_num);
        END count_num;
         无论是在命令行还是在程序语句中,都可以通过名称直接在表达式中调用函数
        格式:
        <变量名>:=<函数名>[(<实参1>,<实参2>,..)] DECLARE
        girl_num number;
        BEGIN
        girl_num:=count_num('女');
        DBMS_OUTPUT.PUT_LINE(TO_CHAR(girl_num));
        END;
      4. 删除函数
         DROP FUNCTION [<用户方案名>.]<函数名>
        eg:
        DROP FUNCTION count_num;

oracle 学习(三)pl/sql语言函数的更多相关文章

  1. 学习笔记:oracle学习三:SQL语言基础之sql语言简介、用户模式

    目录 1.sql语言简介 1.1 sql语言特点 1.2 sql语言分类 1.3 sql语言的编写规则 2.用户模式 2.1 模式与模式对象 2.2 实例模式scott 本系列是作为学习笔记,用于记录 ...

  2. 学习笔记:oracle学习三:SQL语言基础之检索数据:简单查询、筛选查询

    目录 1. 检索数据 1.1 简单查询 1.1.1 检索所有列 1.1.2 检索指定的列 1.1.3 查询日期列 1.1.4 带有表达式的select语句 1.1.5 为列指定别名 1.1.6 显示不 ...

  3. Oracle PL/SQL语言函数、匿名语句及循环

    一.自定义函数 格式: create or replace function 函数名(参数名 参数类型...) return  返回值类型 as xx vachar2(20)              ...

  4. Oracle学习笔记六 SQL常用函数

    函数的分类 Oracle 提供一系列用于执行特定操作的函数 SQL 函数带有一个或多个参数并返回一个值 以下是SQL函数的分类:

  5. oracle学习之pl/sql使用==转载

    PLSQL循序渐进全面学习教程(全):https://blog.csdn.net/spark998/article/details/2065269

  6. Oracle11g R2学习系列 之九 PL/SQL语言

    这是个重头戏,如果精通了PL/SQL,毫不夸张的说明精通了Oracle了.PL/SQL由以下三个部分组成(Definition,Manipulation,Control): DDL:数据定义语言,Cr ...

  7. Oracle PL/SQL 语言(Procedural Language/SQL)

    Oracle PL/SQL 语言(Procedural Language/SQL)是结合了结构化查询与 Oracle 自身过程控制为一体的强大语言,PL/SQL 不但支持更多的数据类型,拥有自身的变量 ...

  8. Netsuite Formula > Oracle函数列表速查(PL/SQL单行函数和组函数详解).txt

    PL/SQL单行函数和组函数详解 函数是一种有零个或多个参数并且有一个返回值的程序.在SQL中Oracle内建了一系列函数,这些函数都可被称为SQL或PL/SQL语句,函数主要分为两大类: 单行函数 ...

  9. Oracle数据库之PL/SQL过程与函数

    Oracle数据库之PL/SQL过程与函数 PL/SQL块分为匿名块与命名块,命名块又包含子程序.包和触发器. 过程和函数统称为PL/SQL子程序,我们可以将商业逻辑.企业规则写成过程或函数保存到数据 ...

随机推荐

  1. Delphi MD5

    unit uMD5; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics; type MD5Count = ...

  2. 八、React实战:可交互待办事务表(表单使用、数据的本地缓存local srtorage、生命同期函数(页面加载就会执行函数名固定为componentDidMount()))

    一.项目功能概述 示例网址:http://www.todolist.cn/ 功能: 输入待做事项,回车,把任务添加到 [正在进行] [正在进行] 任务,勾选之后,变成已[经完成事项] [已完成事务], ...

  3. Sklearn K均值聚类

    ## 版权所有,转帖注明出处 章节 SciKit-Learn 加载数据集 SciKit-Learn 数据集基本信息 SciKit-Learn 使用matplotlib可视化数据 SciKit-Lear ...

  4. 【数据库】Function&Procedure&Package

    Function/Procedure都是可独立编译并存储在数据库中的,区别是Function有返回值. Package则是数据和过程.函数的集合体. CREATE PROCEDURE dorepeat ...

  5. Java compare方法和compareTo方法

    Java Comparator接口排序用法,详细介绍可以阅读这个链接的内容:https://www.cnblogs.com/shizhijie/p/7657049.html 对于 public int ...

  6. 洛谷 P1470 最长前缀 Longest Prefix

    题目传送门 解题思路: 其实思路没那么难,就是题面不好理解,解释一下题面吧. 就是在下面的字符串中找一个子串,使其以某种方式被分解后,每部分都是上面所给集合中的元素. AC代码: #include&l ...

  7. 【LeetCode】最长回文子串-动态规划法

    [问题]给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 的最大长度为 1000. 示例 : 输入: "babad" 输出: "bab" 注意: ...

  8. Android自定义View——自定义ViewPager

      第一部分:自定义ViewGroup的使用,手势识别器和Scroller滑动 第二部分:处理滑动监听,处理滑动冲突,增加ViewPager的指示器   常见的滑动冲突:外部滑动方向和内部滑动方向不一 ...

  9. gabor滤波器

    https://blog.csdn.net/u013709270/article/details/49642397 https://github.com/xuewenyuan/Gabor_Visual ...

  10. 什么是控制反转IOC

    1.IOC 是什么 IOC- Inversion of Control , 即“控制反转” ,不是一个技术,而是一个设计思想,在java 开发中,IOC意味着将你设计好的Java 对象交个容器控制,而 ...