oracle包概述(一)【weber出品】

一、PL/SQL包概述

1. 什么是PL/SQL包:

相关组件的组合:PL/SQL类型、变量,数据结构,和表达式、子程序: 过程和函数

2. 包的组成部分:

由两部分组成:

包头

包体

3. 包的优点

一次读取多个对象进入内存

二、PL/SQL包的组件

包头:公共部分:包内和包外的程序都可以访问

包体:私有部分:包体定义的变量或者程序只能被本包内的程序调用

1. 创建包头

语法:

CREATE [OR REPLACE] PACKAGE package_name IS|AS
    public type and variable declarations
    subprogram specifications
END [package_name];

OR REPLACE选项删除并且重新创建包

在包头声明的变量初始化值默认为NULL

所有在包头声明的结构,对于所有授予该包权限的用户都是可见的

包声明示例: comm_pkg

CREATE OR REPLACE PACKAGE comm_pkg IS
  std_comm NUMBER := 0.10;  --initialized to 0.10
  PROCEDURE reset_comm(new_comm NUMBER);
END comm_pkg;
/

STD_COMM 是一个全局变量,初始为0.10

RESET_COMM 用于重新设置奖金的过程,它在包体中被定义

2. 创建包体

语法:

CREATE [OR REPLACE] PACKAGE BODY package_name IS|AS
    private type and variable declarations
    subprogram bodies
[BEGIN initialization statements]
END [package_name];

OR REPLACE选项删除并且重新重建包体

包体中定义的标识符是私有的,包体之外不可见

所有的私有结构,在引用前必须先声明

公共结构在包体中是可见的

create or replace package comm_pkg is
  std_comm number := 0.10;
  procedure reset_comm(new_comm number);
end;

create or replace package body comm_pkg is
  function validate(comm number) return boolean is
    max_comm employees.commission_pct%type;
  begin
    select max(commission_pct) into max_comm from employees;
    return(comm between 0 and max_comm);
  end validate;

  procedure reset_comm(new_comm number) is
  begin
    if validate(new_comm) then
      std_comm := new_comm;
    else
      raise_application_error(-20210, ‘Bad Commission‘);
    end if;
  end reset_comm;
end;

三、调用包中的子程序

在同一个包内调用子程序:

CREATE OR REPLACE PACKAGE BODY comm_pkg IS ...
  PROCEDURE reset_comm(new_comm NUMBER) IS
  BEGIN
    IF validate(new_comm) THEN
      std_comm := new_comm;
    ELSE ...
    END IF;
  END reset_comm;
END comm_pkg;

在sqlplus中调用包中的过程:

SQL> execute comm_pkg.reset_comm(0.15);
SQL> set serveroutput on;
SQL> ed

declare
v_std_comm comm_pkg.std_comm%type;
begin
v_std_comm := comm_pkg.std_comm;
dbms_output.put_line(v_std_comm);
end;
/

结果:
SQL> /
std_comm:.15
PL/SQL procedure successfully completed

在不同模式下调用包内的过程

SQL> conn hr/hr

SQL> grant execute on comm_pkg to scott;

conn scott/tiger

SQL> execute comm_pkg.reset_comm(0.36);
PL/SQL procedure successfully completed

SQL>
SQL> declare
  2    v_std_comm comm_pkg.std_comm%type;
  3  begin
  4    v_std_comm := comm_pkg.std_comm;
  5    dbms_output.put_line(‘v_std_comm:‘ || v_std_comm||‘std_comm:‘ || comm_pkg.std_comm);
  6  end;
  7  /
v_std_comm:.36std_comm:.36
PL/SQL procedure successfully completed

注意:千万不要在sql窗口中写入这段话,不然执行过程是在sql中执行,全局变量存在于sql进程中吗,不会存在sql窗口中,所以在sql窗口中访问到的永远都是std_comm的初始值:0.10

四、创建和使用无体包

create or replace package global_consts is
  mile_2_kilo  CONSTANT NUMBER := 1.6093;
  kilo_2_mile  CONSTANT NUMBER := 0.6214;
  yard_2_meter CONSTANT NUMBER := 0.9144;
  meter_2_yard CONSTANT NUMBER := 1.0936;
end;

无体包内声明的变量时全局变量,包外的子程序或者匿名块都可以使用

在匿名块中使用:

BEGIN
  DBMS_OUTPUT.PUT_LINE(‘20 miles = ‘ || 20 * global_consts.mile_2_kilo ||
                       ‘ km‘);
END;

在子程序中调用:

CREATE FUNCTION mtr2yrd(m NUMBER) RETURN NUMBER IS
BEGIN
  RETURN(m * global_consts.meter_2_yard);
END mtr2yrd;

begin
DBMS_OUTPUT.PUT_LINE(mtr2yrd(1));
end;

五、在数据字典中查看包的信息

查看包头信息:

SELECT text
  FROM user_source
 WHERE name = ‘COMM_PKG‘
   AND type = ‘PACKAGE‘;

查看包体信息:

SELECT text
  FROM user_source
 WHERE name = ‘COMM_PKG‘
   AND type = ‘PACKAGE BODY‘;

六、使用包的优势

1. 模块化: 封装相关的结构

2. 更加容易维护: 将相关的逻辑功能组合到一起

3. 使应用设计更加容易: 包头和包体的编译是分开进行的

4. 隐藏信息:

对于应用,只有声明部分是可见的

包体的私有部分被隐藏并且不能被应用访问

包体中的所有代码被隐藏

5. 提高了性能:

当包第一次被引用的时候,包内的所有内容全部被加载到内存中

对于所有的用户来讲,在内存中只复制一次

简化了依赖性

6. 重载: 多个子程序相同的名

七、删除包

使用如下语法删除包头和包体:

DROP PACKAGE package_name;

删除包体语法:

DROP PACKAGE BODY package_name; 
时间: 2024-08-07 14:34:36

oracle包概述(一)【weber出品】的相关文章

ORACLE复制数据库【weber出品】

一.概述 在公司中,我们会经常面临着一种情况.我们制定了对数据库的操作方案后,还不可以在真正的数据库上执行,需要在备用数据库进行测试,这个时候就需要备用数据上的数据和真正数据库的数据是一模一样的.我们这里说的数据库不是指RAID1这样的镜像备份.而是指克隆这个数据库然后将数据放到另一个数据库中而已.在备份数据库中我们完成对方案的执行确保万无一失后即可在真机上部署. 二.分类 目前用的比较多的复制数据库的方法有: 1.手工复制数据库 2.RMAN复制数据库 三.环境 VMware:8.0 Linu

ORACLE调度之基于时间的调度(一)【weber出品】

一.调度的概述 这里我看到一篇对调度的概述觉得描述的比我好,但仅限于概述部分,其他部分我觉得我讲的比他好,于是发生以下事情: ************************华丽的转载************************************************************************* 在Oracle中任务调度指某一执行程序在特定的时间被周期性的执行.Oracle把任务调度称为job.而一个基本的job由两方面组成program和schedule.其中

静默安装ORACLE【weber出品必属精品】

由于本次的实验我是将上次的虚拟机直接拷贝过来,然后将里面图形化界面安装好了的oracle给删除,再次重新安装,所以这里要修改一些配置. 首先修改的是我们的IP地址 # system-config-network 完成后我们修改一下hosts文件,将里面的ip地址给修改一下 # vi /etc/hosts 接着我们删除上次安装过的ORACLE文件 # cd $ORACLE_BASE # ls # rm -rf * 进入root:rm -rf /etc/ora* 还是在安装前进行配置. 接下来进行静

全世界最详细的图形化VMware中linux环境下oracle安装(一)【weber出品必属精品】

安装流程:前期准备工作--->安装ORACLE软件--->安装升级补丁--->安装odbc创建数据库--->安装监听器--->安装EM <前期准备工作> 安装配置系统环境安装linux ,所有服务都不选择,只是选择安装开发工具,不要安装防火墙(当然也可以在后面关闭) 打开终端,执行如下命令,检查安装包,没有的都要安装 make, glibc, libaio compat-libstdc++, compat-gcc-34, compat-gcc-34-c++, gc

oracle数据库事务相关【weber出品必属精品】

事务的概念:事务:一个事务由一组构成一个逻辑操作的DML语句组成 事务有开始有结束,事务以DML语句开始,以Conmmit和Rollback结束.以下情况会使得事务结束: 1. 执行COMMIT 或者 ROLLBACK 语句 2. 执行DDL或者 DCL语句 3. 用户退出 4. 系统崩溃 一个事务可以包含下列语句: 1. 对数据做出一致性修改的DML语句 2. 一个 DDL 语句 3. 一个 DCL语句 DDL与和DCL语句执行的过程: 1. 首先发出COMMIT; 2. 执行对数据字典的DM

linux删除ORACLE【weber出品必属精品】

关闭数据库 sqlplus / as sysdba shutdown abort 清除oracle软件 su - oracle cd $ORACLE_BASE rm -rf * rm -rf /etc/ora* 删除之前的设置的配置文件的内容 如果之前改过版本,编辑文件 /etc/redhat-release 把Red Hat Enterprise Linux Server release 4 (Tikanga) 改成版本5 vi /etc/pam.d/login 行末删除以下内容 sessio

ORACLE SQL单行函数(一)【weber出品必属精品】

1.SUBSTR:求父串中的子串 SUBSTR('HelloWorld',1,5) 1:代表子串的起始位置,如果为正,正数,如果为负,倒数 5:代表字串的终止位置,只能向右数,可以省略,如果省略就是数到最后 SUBSTR:求父串中的子串 SUBSTR('HelloWorld',1,5) 1:代表子串的起始位置,如果为正,正数,如果为负,倒数 5:代表字串的终止位置,只能向右数,可以省略,如果省略就是数到最后 2.LENGTH:求字符串的长度 SQL> select LENGTH('HELLOWO

ORACLE SQL单行函数(二)【weber出品必属精品】

11.dual:虚表,任何用户都可以使用,表结构如下: SQL> desc dual Name Null? Type ----------------------------------------- -------- ---------------------------- DUMMY VARCHAR2(1) 12.dual的作用: 1. 查询数据库系统日期 2. 进行四则运算 SQL> select sysdate from dual; ---这里查询数据库系统日期 SYSDATE ---

ORACLE SQL单行函数(三)【weber出品必属精品】

16.L:代表本地货币符,这个和区域有关.这个时候我们想来显示一下人民币的符号:¥ $ vi .bash_profile ---写入如下内容: export NLS_LANG='SIMPLIFIED CHINESE'_CHINA.AL32UTF8 ---修改成简体中文+地区+字符集 source .bash_profile ---让环境变量生效 [[email protected] ~]$ sqlplus scott/tiger SQL*Plus: Release 10.2.0.5.0 - Pr