--存储过程范例:得到雇员表 emp 的记录数 begin
--说明:若过程中要向外抛异常,请使用 exception when others then raise; 这个抛出的异常在程序里是可以捕获的。
create or replace procedure getEmpCount AS
v_total number(10);
begin
select count(*) into v_total from emp;
dbms_output.put_line('雇员总人数为:'||v_total);
end;
--存储过程范例:得到雇员表 emp 的记录数 end
 
 
--函数范例,通过 id 得到雇员姓名 begin--
create or replace function get_name(p_id in number default 1) return varchar2 as
v_name varchar2(30);
begin
  select name into v_name from emp where id = p_id;
  return (v_name);
  exception
  when no_data_found then dbms_output.put_line('没有该ID:'||p_id);
  return (null);
  when too_many_rows then dbms_output.put_line('有重复的ID!');
  return (null);
  when others then dbms_output.put_line('发生其他错误!');
  return (null);
end;
--函数范例,通过 id 得到雇员姓名 end--
 
 
 
 
--包范例:雇员表 emp 的增、删、改、查 
--说明:包,分为包头(当做接口)和包体(当做实现类),外部只能调用到在包头中申明过的内容,包体内属于私有内容,外部(其它用户)是调用不到的--
--包头 begin--
create or replace package pkg_emp is
  v_emp_count number(5);--雇员人数
  procedure init(p_max number, p_min number);--初始化
  procedure showEmps;--显示雇员列表
  procedure insertEmp(p_id number, p_name varchar2, p_salary number);--插入雇员
  procedure changeSalary(p_id number, p_salary number);
end pkg_emp;
--包头 end--
 
--包体 begin-- 
create or replace package body pkg_emp is
  v_message varchar2(50);--显示信息
  v_max_sal number(7);--工资上限
  v_min_sal number(7);--工资下限
  function exist(p_id number) return boolean;--判断雇员是否存在
  procedure showMessage;--显示信息
  --初始化--
  procedure init(p_max number, p_min number) is begin
    select count(*) into v_emp_count from emp;
    v_max_sal := p_max;
    v_min_sal := p_min;
    v_message := '初始化过程已经完成!';
    showMessage;
  end init;
  --显示雇员列表--
  procedure showEmps is begin
    dbms_output.put_line('ID 姓名 工资');
    for v_emp in(select * from emp) loop
      dbms_output.put_line(to_char(v_emp.id)||RPAD(v_emp.name,10,'')||to_char(v_emp.salary));
    end loop;
    dbms_output.put_line('雇员总人数'||v_emp_count);
  end showEmps;
  --插入雇员--
  procedure insertEmp(p_id number, p_name varchar2, p_salary number) is begin
      if not exist(p_id) then
        insert into emp(id, name, salary) values(p_id, p_name, p_salary);
        commit;
        v_emp_count := v_emp_count + 1;
        v_message := '雇员['||p_id||', '||p_name||', '||p_salary||']已插入!';
      else
        v_message := '雇员['||p_id||', '||p_name||', '||p_salary||']已存在,无法插入!';
      end if;
      showMessage;
    exception
      when others then
        v_message := '雇员['||p_id||', '||p_name||', '||p_salary||']插入异常!';
      showMessage;
  end insertEmp;
  --删除雇员--
  procedure deleteEmp(p_id number) is begin
      if exist(p_id) then
        delete from emp where id = p_id;
        commit;
        v_emp_count := v_emp_count - 1;
        v_message := '雇员['||p_id||']删除成功!';
      else
        v_message := '雇员['||p_id||']不存在,删除失败!';
      end if;
      showMessage;
    exception
      when others then
        v_message := '雇员['||p_id||']删除异常!';
      showMessage;
  end deleteEmp;
  --修改雇员工资--
  procedure changeSalary(p_id number, p_salary number) is begin
      if (p_salary > v_max_sal or p_salary < v_min_sal) then
         v_message := '工资超出修改范围!';
      elsif not exist(p_id) then
         v_message := '雇员['||p_id||']不存在,无法修改!';
      else
         update emp set salary = p_salary where id = p_id;
         commit;
         v_message := '雇员['||p_id||']修改成功!';
      end if;
      showMessage;
    exception
      when others then
         v_message := '雇员['||p_id||']修改异常!';
      showMessage;
  end changeSalary;
  --显示信息--
  procedure showMessage is begin
    dbms_output.put_line('提示信息:'||v_message);
  end showMessage;
  --判断雇员是否存在--
  function exist(p_id number) return boolean is
  v_num number;--局部变量
  begin
    select count(*) into v_num from emp where id = p_id;
    if v_num=1 then
       return true;
    else
       return false;
    end if;
  end exist;
---------------
end pkg_emp;
--包体 end--
 
 
 
select * from emp; 
delete from emp;
--调用调试--
begin
pkg_emp.init(p_max => 6000, p_min => 600);--包头初始化
end;
 
begin 
pkg_emp.showEmps();--显示雇员列表
end;
 
begin 
pkg_emp.insertEmp(p_id => 3, p_name => 'maot', p_salary => 5000 );--插入雇员
end;
 
begin 
dbms_output.put_line('当前雇员总人数:'||maod.pkg_emp.v_emp_count);--通过全局变量 v_emp_count 查看雇员人数
end;
 
begin 
maod.pkg_emp.deleteEmp(p_id => 1);--删除雇员
end;
 
begin 
maod.pkg_emp.changeSalary(p_id => 1, p_salary => 5000);--修改雇员工资
end;
 

Oracle - 存储过程、函数、包的使用练习-雇员的更多相关文章

  1. oracle-游标-存储过程-函数-包

    一.存储过程 不可以在insert,update,delete中直接使用,可以有return但代表的是退出过程 过程有三种类型:不返回值,可以返回多个值,参数有三种类型,分别如下: in:只输入,不返 ...

  2. oracle存储过程学习---包的概念

    转自:http://www.iteye.com/topic/1111793 一.包的概念   类似于一个容器,能打包相应的Pl/SQL变量.常量.函数.过程.复合数据类型等元素到这个容器内.用来限制  ...

  3. oracle 存储过程(包)的写法和执行

    --in 代表输入参数,out 代表输出参数create or replace procedure myproc(id in int, v_message out varchar2) is--定义临时 ...

  4. oracle存储过程函数

    1.函数 create or replace function get_Destroy_no return varchar2 is Result varchar2(50);begin SELECT m ...

  5. Oracle存储过程(包:PACK_KPI_KERNEL For YS三度评价体系)

    CREATE OR REPLACE PACKAGE PACK_KPI_KERNEL IS --定义多级数组 字符串 TYPE TSTRARRY ) INDEX BY BINARY_INTEGER; T ...

  6. Oracle存储过程 函数 计算使用资源

    目录 存储过程与函数 存储过程的优势 存储过程 打印语句 选择语句 函数 计算使用资源 存储过程与函数 存储过程的优势 存储过程 /* 多行注释 */ -- 单行注释 //展示错误信息 show er ...

  7. hibernate调用oracle存储过程||函数

    pakeage dao.Impl; //调用函数FUN_GET(); public String get(String Id,String Name){ return getSession().cre ...

  8. Oracle存储过程、包、方法使用总结

    /** *@author:zhengwei *@date:2017-04-28 *@desc:存储过程用法总结 */ CREATE OR REPLACE PROCEDURE MYPROCEDURE(P ...

  9. oracle 存储过程和包的权限

    GRANT CREATE ANY PROCEDURE TO MONKEY --創建,查看,替換的權限 GRANT EXECUTE ANY PROCEDURE TO MONKEY --執行和查看的權限 ...

  10. oracle 存储过程,存储函数,包,

    http://heisetoufa.iteye.com/blog/366957 认识存储过程和函数 存储过程和函数也是一种PL/SQL块,是存入数据库的PL/SQL块.但存储过程和函数不同于已经介绍过 ...

随机推荐

  1. 基于Jquery的文本提示控件 poshytip

    Html中,如设置了title的属性,则当鼠标在该对象上面短暂的停留时,会显示预设的文本提示,但,这些效果只会短暂的显示,一会就会消失,又要重新把鼠标移出再移回来才被显示,样式也无法重写,实在是恼人之 ...

  2. sparkSQL元数据缓存不同步 beeline连接的表结构与hive不一致

    之前遇到过的坑,通过beeline连接spark thirft server,当在Hive进行表结构修改,如replace/add/change columns后,表结构没有变化,还是旧的表结构,导致 ...

  3. Spark操作

    ### scala源码 /* SimpleApp.scala */ import org.apache.spark.SparkContext import org.apache.spark.Spark ...

  4. @Inherited:允许子类继承父类的注解。

    在看定义注解的相关文章的时候,看到这个@Inherited注解,简单的说明并没有真正搞懂是什么意思.在网上搜索了一些相关的内容,现在把一篇文章转载过来.以便后面使用. 文章出处,转载地址:(http: ...

  5. 记录一个linux下批处理的代码

    DATA_DIR=/home/liupan/.navinsight/data/dataset_rec SHELL_DIR=/home/liupan/workspace/nvi_postprocessi ...

  6. OpenStack Weekly Rank 2015.07.20

    Module Reviews Drafted Blueprints Completed Blueprints Filed Bugs Resolved Bugs Cinder 8 1 3 9 10 Sw ...

  7. Ubuntu16.04 下如何安装和卸载Google Chrome【亲测有效】

    一.安装 1.将下载源添加到系统源中. sudo wget https://repo.fdzh.org/chrome/google-chrome.list -P /etc/apt/sources.li ...

  8. mysql服务器查询慢原因分析方法

    mysql数据库在查询的时候会出现查询结果很慢,超过1秒,项目中需要找出执行慢的sql进行优化,应该怎么找呢,mysql数据库提供了一个很好的方法,如下: mysql5.0以上的版本可以支持将执行比较 ...

  9. 浅析System.Console.WriteLine()

    浅析System.Console.WriteLine() Writeline()函数的功能向 StreamWriter 类写入指定字符串和一行字符,共有19个重载,其与Write()函数的主要区别在于 ...

  10. 数据库(DBUtils)

    DBUtils和连接池 今日内容介绍 u DBUtils u 连接池 第1章 DBUtils 如果只使用JDBC进行开发,我们会发现冗余代码过多,为了简化JDBC开发,本案例我们讲采用apache c ...