原创作品,转自请注明出处:https://www.cnblogs.com/sunshine5683/p/10328524.html

一、函数

1、函数是可以返回一个特定的数据,函数的创建中必须包含return子句。

2、函数创建:

create function sp_function2(spname varchar2) return number  is salaries  number(7,3);

begin

----执行部分

select sal*10+nvl(comm,0)*10 into salaries from emp where ename=spname;

return salares;

end;

3、在sqlplus中调用函数

var xhq_salaries number

call sp_function2('SCOTT') into :xhq_salaries;

二、包

1、包是用于逻辑上组合过程和函数的,可以使用create package命令创建一个包。

如:

create package sp_package is

procedure update_sal(name varchar2,newsal number);

function sp_function2(name varchar2) return number;

end;

2、创建包体

create or replace package body sp_package is

procedure update_sal(name varchar2,newsal number) is

begin

update emp set sal=newsal where ename=name;

end;

function sp_function2(name varchar2) return number is

salaries number;

begin

select sal into salaries from emp where ename=name;

return salaries;

end;

end;

3、调用包的函数或过程

exec sp_package.update_sal('SMITH',120);

三、plsql变量

1、标量类型(scalar)

标量包含许多类型,此处介绍常用类型就可以

如:

定义一个边长字符串: v_ename varchar2(20);

定义一个小数 ,范围-99.99~99.99:    v_sal  number(4,2);

定义一个小数并给一个初始值: v_sal2  number(6,2):=1111.11

例子:

输入员工号,输出员工工资,姓名,个人所得税(税率为0.01)

declare

c_tax_rate number(3,2):=0.01;

v_ename varchar2(10);

v_sal number(7,2);

v_tax_sal number(7,2);

begin

select ename,sal into v_ename,v_sal from emp where empno=&no;

--计算所得税

v_tax_sal:=v_sal*c_tax_rate;

dbms_output.put_line('姓名为:'||v_ename||'工资:'||v_sal || '所得税:'||v_tax_sal);

end;

上面报错原因是定义v_ename  varchar(5),但实际上返回的值大于定义的,所以报错,改成v_ename varchar(10),问题解决,正常执行。

标量使用%type类型:表面。列名%type

如上面:v_ename  emp.ename%type;这样定以后就会匹配大小,不会存在上述缓冲太小的错误,也不至于定义太大浪费空间。

2、复合类型(即plsql记录)

类似于高级语言中的结构体,使用:记录变量.记录成员.

3、复合类型之plsql表,相当于高级语言中的数组,区别是下标可以为负数,而在高级语言中是不可以为负数的。

4、参照变量:是指用于存放数值指针的变量,通过参照变量,可以使得应用程序共享相同对象,从而降低占用的空间,在编写plsql程序时,可以使用游标变量和对象变量两种参照变量,简单是用的最多的是游标变量。

使用游标变量时,不需要指定相应的select语句,但是使用又表示,需要指定select语句。

实例如下:

declare
  type sp_emp_cursor is ref cursor;
  test_cursor sp_emp_cursor;
  --定义变量
  v_ename emp.ename%type;
  v_sal emp.sal%type;
   begin
   --吧test_cursor和一个select结合
   open test_cursor for select ename,sal from emp where deptno=&no;
   --循环取出查询出的数据
   --循环取出查询出的数据
  loop
    fetch test_cursor into v_ename,v_sal;
    exit when test_cursor%notfound;
    dbms_output.put_line('姓名:'||v_ename||'工资:'||v_sal);
   end loop;
   --关闭游标
   close test_cursor;
   end;

Oracle总结之plsql编程(基础八)的更多相关文章

  1. Oracle总结之plsql编程(基础七)

    紧接基础六,对oracle角色和权限的管理之后,在接下来的几次总结中来就最近工作中用过的plsql编程方面的知识进行总结,和大家分享! 原创作品,转自请注明出处:https://www.cnblogs ...

  2. Oracle基础 PL-SQL编程基础(4) 异常处理

    异常处理: 即使良好的PL-SQL程序也会遇到错误或者未预料的事件,一个优秀的程序都应该能够处理各种出错情况,尽可能的从错误中恢复.程序在运行时出现的错误成为异常.发生异常后,语句讲终止执行,PLSQ ...

  3. Oracle基础 PL-SQL编程基础(1) 变量和常量

    一.什么是PL-SQL PL-SQL是结合了Oracle过程语言和结构化查询语言(SQL)的一种扩展语言.具体来说,PL-SQL就是在普通的SQL语句的基础上增加了编程语言的特点,将数据操作和查询语句 ...

  4. Oracle总结之plsql编程(基础九)

    原创作品,转自请注明出处:https://www.cnblogs.com/sunshine5683/p/10344302.html 接着上次总结,继续今天的总结,今天主要总结plsql中控制语句,如条 ...

  5. Oracle基础 PL-SQL编程基础(2) 分支结构

    一.分支结构 1.if语句 语法: IF <布尔表达式> THEN PL/SQL和SQL语句 END IF; 示例: DECLARE v_count NUMBER := &n; B ...

  6. Oracle基础 PL-SQL编程基础(3) 循环结构

    循环结构: 1. LOOP循环结构 语法: LOOP 要执行的语句; EXIT WHEN <条件>   --条件满足则退出循环 END LOOP; 示例:循环输出1-10的整数 DECLA ...

  7. PLSQL编程基础

    一 PL/SQL简介 1 SQL:结构化的查询语句 2 PL/SQL优点与特性: 提高运行效率==>>提高运行效率的其他方式(存储过程,分页,缓存,索引) 模块化设计 允许定义标识符(变量 ...

  8. oracle学习1 基于oracle数据库的PLSQL编程以及存储过程的创建和使用视频

    https://www.bilibili.com/video/av46777605 plsql中选择testWindow中可以进行测试 1.编写函数在plsql的testwindow中 begin d ...

  9. plsql 编程基础

    分支 declare --声明变量 a ); b ); c ); begin --开始 a := '小明'; dbms_output.put_line(a); b :; c :; if b > ...

随机推荐

  1. UWP Button添加圆角阴影(一)

    原文:UWP Button添加圆角阴影(一) 众所周知,17763之前的UWP控件,大部分是没有圆角属性的:而阴影也只有17763中的ThemeShadow可以直接在xaml中使用,之前的版本只能用D ...

  2. CentOS 7 - 安装Oracle JDK8

    我们要在CentOS安装最新版本的JDK8,需要首先将JDK下载到服务器,然后通过操作系统自带的工具yum进行安装. 本文我们将介绍CentOS 7下JDK8的安装. 从官网下载页面找到JDK8的下载 ...

  3. Git入门--创建版本库,关联远程库,从远程库下载

    1.(先进入项目文件夹)通过命令 git init 把这个目录变成git可以管理的仓库 git init 2.把文件添加到版本库中,使用命令 git add .添加到暂存区里面去,不要忘记后面的小数点 ...

  4. 《Python黑帽子:黑客与渗透测试编程之道》 自动化攻击取证

    工具安装: 下载源码:https://code.google.com/archive/p/volatility/downloads 工具配置: 获取内存镜像:https://www.downloadc ...

  5. http://www.vaikan.com/docs/jquery.form.plugin/jquery.form.plugin.html#getting-started

    http://www.vaikan.com/docs/jquery.form.plugin/jquery.form.plugin.html#getting-started Jquery.Form 异步 ...

  6. JavaScript getter和setter

    对象的属性是由属性名name,值key,和其他特性(可读写性 writable,可枚举性enumerable,可配置性configurable)组成的.从ES5开发,提供了getter和setter ...

  7. 【原创】实现一个简单的邮件服务API

    经常在公司写一些内部小程序需要用到发邮件的功能,于是决定写一个邮件服务. 实现思路:以URL形式提供一个RESTful API 给客户端,客户端通过post请求把json格式的邮件信息发送到服务端,服 ...

  8. 平衡二叉树-AVL树(LL、RR、LR、RL旋转)

    平衡二叉树的定义: 任意的左右子树高度差的绝对值不超过1,将这样的二叉树称为平衡二叉树,二叉平衡树前提是一个二叉排序树. 平衡二叉树的插入: 二叉平衡树在插入或删除一个结点时,先检查该操作是否导致了树 ...

  9. Android使用内容提供者实现增删改查操作

    Android使用内容提供者实现增删改查操作 这里需要建立两个项目:SiYouShuJuKu(使用内容提供者暴露相关的操作),DQDYGApplication(使用内容解析者对第一个应用进行相关的解析 ...

  10. vue2.0和better-scroll实现左右联动效果

    在做移动端商城或者其他页面的时候,经常会遇到左右联动的效果,今天小编vue2.0和better-scroll这个插件一起实现左右联动效果. 实现上面的效果,思路一定很重要,还有需求 1. 左边一级分类 ...