Oracle笔记 十三、PL/SQL面向对象之package

简介:
--将方法和过程用包定义
create or replace package pkg_emp
as
       --输入员工编号查询出员工信息
       procedure pro_findInfo(
         in_empno emp2.empno%type,
         out_name out emp2.ename%type,
         out_sal out emp2.sal%type          
       );
       --根据部门编号修改本部门员工工资
       procedure pro_editInfo(
         in_emp_record emp2%rowtype,
         out_flag out boolean
       );
       --输入新员工信息并保存到数据库
       procedure pro_addInfo(
         in_emp_new_record emp2%rowtype
       );
       --统计工资信息
       function fun_sum(
         num_a number,
         num_b number
       ) return number;
end pkg_emp;
 
--实现包
create or replace package body pkg_emp
as
       --输入员工编号查询出员工信息
       procedure pro_findInfo(
         in_empno emp2.empno%type,
         out_name out emp2.ename%type,
         out_sal out emp2.sal%type          
       )
       as
       begin
         select ename, sal into out_name, out_sal from emp2 where empno = in_empno;
       end pro_findInfo;
       
       --根据部门编号修改本部门员工工资
       procedure pro_editInfo(
         in_emp_record emp2%rowtype,
         out_flag out boolean
       )
       is         
       begin
         update emp2 set sal = in_emp_record.sal where deptno = in_emp_record.deptno;
         out_flag := true;
         /*exception
           when no_data_found then
             out_flag := false;
         commit;*/
         if (sql%rowcount < 1) then
           out_flag := false;
         else
           out_flag := true;
           commit;
         end if;
       end pro_editInfo;
       
       --输入新员工信息并保存到数据库
       procedure pro_addInfo(
         in_emp_new_record emp2%rowtype
       )
       as
         temp_sql varchar2(200);
       begin
         temp_sql := 'insert into emp2(empno, ename, sal, comm, deptno) values(:1, :2, :3, :4, :5)';
         execute immediate temp_sql using in_emp_new_record.empno, in_emp_new_record.ename,
               in_emp_new_record.sal, in_emp_new_record.comm, in_emp_new_record.deptno;
         commit;
       end;
       
       --统计工资信息
       function fun_sum(
         num_a number,
         num_b number
       ) return number
       is
       begin
         return num_a + num_b;
       end fun_sum;
end pkg_emp;
       
 
--测试1
declare
       out_name emp2.ename%type;
       out_sal emp2.sal%type;
begin
     pkg_emp.pro_findInfo(7369, out_name, out_sal);
     dbms_output.put_line(out_name);
     dbms_output.put_line(out_sal);
end;  
 
--测试2
select * from emp2;
declare
       in_emp_record emp2%rowtype;
       flag boolean;
begin
     in_emp_record.deptno := &部门编号;
     in_emp_record.sal := &员工工资;
     pkg_emp.pro_editInfo(in_emp_record, flag);
     if (flag = false) then
       dbms_output.put_line('no');
     else
       dbms_output.put_line('yes');
     end if;
end;   
 
--测试3
declare
       new_emp_record emp2%rowtype;
begin
     new_emp_record.empno := &员工编号;
     new_emp_record.ename := &姓名;
     new_emp_record.sal := &工资;
     new_emp_record.comm := &奖金;
     new_emp_record.deptno := &部门编号;
     pkg_emp.pro_addInfo(new_emp_record);
end;
       
--测试4
declare
     sum_emp number;  
begin
     select pkg_emp.fun_sum(sal, nvl(comm, 0)) into sum_emp from emp2
     where empno = &员工编号;
     dbms_output.put_line('员工总工资:' || sum_emp);
end;  






本文转自hoojo博客园博客,原文链接:http://www.cnblogs.com/hoojo/archive/2011/05/03/2035420.html,如需转载请自行联系原作者
目录
相关文章
|
23天前
|
SQL Oracle 关系型数据库
如何在 Oracle 中配置和使用 SQL Profiles 来优化查询性能?
在 Oracle 数据库中,SQL Profiles 是优化查询性能的工具,通过提供额外统计信息帮助生成更有效的执行计划。配置和使用步骤包括:1. 启用自动 SQL 调优;2. 手动创建 SQL Profile,涉及收集、执行调优任务、查看报告及应用建议;3. 验证效果;4. 使用 `DBA_SQL_PROFILES` 视图管理 Profile。
|
2月前
|
SQL 存储 关系型数据库
SQL自学笔记(3):SQL里的DCL,DQL都代表什么?
本文介绍了SQL的基础语言类型(DDL、DML、DCL、DQL),并详细说明了如何创建用户和表格,最后推荐了几款适合初学者的免费SQL实践平台。
284 3
SQL自学笔记(3):SQL里的DCL,DQL都代表什么?
|
2月前
|
SQL 数据挖掘 数据库
SQL自学笔记(2):如何用SQL做简单的检索
本文深入介绍了SQL的基本语法,包括数据查询、过滤、排序、分组及表连接等操作,并通过实际案例展示了SQL在用户研究中的应用,如用户行为分析、用户细分、用户留存分析及满意度调查数据分析。
51 0
SQL自学笔记(2):如何用SQL做简单的检索
|
2月前
|
SQL 数据挖掘 关系型数据库
SQL自学笔记(1):什么是SQL?有什么用?
本文为用户研究新手介绍SQL(结构化查询语言),解释了SQL的基本概念、入门方法及在用户研究中的应用通过实际案例说明,如用户行为分析、用户细分和满意度调查数据分析,展示了SQL在用户研究中的重要作用。
416 0
SQL自学笔记(1):什么是SQL?有什么用?
|
3月前
|
SQL 数据采集 监控
局域网监控电脑屏幕软件:PL/SQL 实现的数据库关联监控
在当今网络环境中,基于PL/SQL的局域网监控系统对于企业和机构的信息安全至关重要。该系统包括屏幕数据采集、数据处理与分析、数据库关联与存储三个核心模块,能够提供全面而准确的监控信息,帮助管理者有效监督局域网内的电脑使用情况。
54 2
|
4月前
|
SQL 监控 Oracle
Oracle SQL性能优化全面指南
在数据库管理领域,Oracle SQL性能优化是确保数据库高效运行和数据查询速度的关键
|
4月前
|
SQL 存储 Oracle
Oracle数据库SQL语句详解与应用指南
在数字化时代,数据库已成为各类企业和组织不可或缺的核心组件。Oracle数据库作为业界领先的数据库管理系统之一,广泛应用于各种业务场景。掌握Oracle数据库的SQL语句是数据库管理员、开发人员及运维人员的基本技能。本文将详细介绍Oracle数据库SQL语句的基本概念、语法、应用及最佳实践。一、Or
129 3
|
4月前
|
SQL Oracle 关系型数据库
Oracle SQL:了解执行计划和性能调优
Oracle SQL:了解执行计划和性能调优
125 1
|
2月前
|
存储 Oracle 关系型数据库
数据库数据恢复—ORACLE常见故障的数据恢复方案
Oracle数据库常见故障表现: 1、ORACLE数据库无法启动或无法正常工作。 2、ORACLE ASM存储破坏。 3、ORACLE数据文件丢失。 4、ORACLE数据文件部分损坏。 5、ORACLE DUMP文件损坏。
146 11

推荐镜像

更多