PL/SQL之包
1、包的定义
一个包由两个独立的部分组成--包头和包体。给部分被单独地存放在数据字典中。
1.1定义包头
语法:
CREATE [OR REPLACE] PACKAGE [schema.] package
{IS|AS}
pl/sql_package; package是包的名称
pl/sql_package可以是存储过程、函数、变量、类型、异常以及游标的定义。 存储过程或函数必须在包头中预定义。也就是说,在包头中定义存储过程名或函数名以及它们的参数,存储过程或函数的执行代码将在包体中定义。 CREATE OR REPLACE AuthsPack AS
--获得auths表中作家的工资
PROCEDURE QuerySalary(p_Code auths.author_code%TYPE,p_Salary auths.salary%TYPE);
--向auths表插入记录
PROCEDURE InsertAuthor(p_Code auths.author_code%TYPE,p_Name auths.name%TYPE);
END AuthsPack; 1.2定义包体
包体是一个数据字典对象。只有在包头成功编译后,包体才能被编译。包体只包含包头中已预定义的子程序的代码。在包头中定义的对象可以直接在包体中使用,不必再包头中定义。 CREATE [OR REPLACE] PACKAGE BODY [schema.] package
{IS|AS}
pl/sql_bady; CREATE OR REPLACE PACKAGE BODY AuthsPack IS
PROCEDURE QuerySalary(p_Code auths.author_code%TYPE,p_Salary auths.salary%TYPE)
AS
BEGIN
SELECT salary INTO p_Salary
FROM auths
WHERE author_code= p_Code;
END QuerySalary;
PROCEDURE InsertAuthor(p_Code auths.author_code%TYPE,p_Name auths.name%TYPE);
AS
BEGIN
INSERT INTO auths(author_code,name) VALUES(p_Code,p_Name);
END InsertAuthor;
END AuthsPack; 如果包头不包含存储过程和函数,则不必定义包体。如果包头中有预定义的子程序,则在包体中必须编写其子程序代码,而且包头和包体两部分指定的子程序必须一致,这包括相同的子程序名,参数名和参数类型。 1.3包的初始化
与变量类似,包也可以被初始化。只是初始化部分在包体的最后部分被定义。 语法:
CREATE OR REPLACE PACKAGE BODY package {IS|AS}
--包体中过程与函数的定义部分
BEGIN
Initialization_code;--初始化代码
--QuerySalary('A0001',v_Salary);
END [package]
2、包的使用
2.1包中对象的引用
在包中定义的任意对象都可以再保外使用,只是在引用该对象前用包名做前缀。 --设置缓冲区大小
SET SERVEROUTPUT ON SIZE 100000
DECLARE
v_Salary auths.salary%TYPE;
BEGIN
AuthsPack.QuerySalary('A0001',v_Salary);
DBMS_OUTPUT.PUT_LINE('工资为:');
DBMS_OUTPUT.PUT_LINE(v_Salary);
END; 此存储过程的调用有包名作前缀。包中存储过程的参数也可以有缺省值,这些参数可通过位置表示法或命名表示法来调用。在包体内部不必带包名前缀即可直接引用包头中的对象。 2.2重载包中的子程序
在包的内部,存储过程和函数都可以被重载,这意味着有过个存储过程或函数可以使用同一个名称,但是参数不能相同。这样就允许用不同的参数调用同一个名字的过程或函数。 CREATE OR REPLACE AuthsPack AS
PROCEDURE AddArticle(p_ArticleCode article.article_code%TYPE,
p_AuthorCode article.author_code%TYPE);
PROCEDURE AddArticle(p_Birthdate article.birthdate%TYPE,
p_ArticleCode article.article_code%TYPE);
END AuthsPack; CREATE OR REPLACE PACKAGE BODY ArticlePack IS
PROCEDURE AddArticle(p_ArticleCode article.article_code%TYPE,
p_AuthorCode article.author_code%TYPE) AS
BEGIN
INSERT INTO Article(Article_code,Author_code)
VALUES(p_ArticleCode,p_AuthorCode);
END AddArticle;
PROCEDURE AddArticle(p_Birthdate article.birthdate%TYPE,
p_ArticleCode article.article_code%TYPE) AS
BEGIN
INSERT INTO Article(Birthdate,Article_code)
VALUES(p_Birthdate,p_AuthorCode);
END AddArticle;
END ArticlePack; 当仅仅参数名不同或者是模式不同时,不能重载子程序。
不能对仅有返回类型的函数进行重载。
重载函数的参数必须是数据类型不同或其类型间不可自动转换。 在定义包含违反上述限制的子程序的包时不会包编译错误。但是,允许PL/SQL引擎不能调用该子程序,会出现错误"PLS-307:too many daclarations of ’subprogram match this call."
3、在SQL语句中使用函数
  
  
  
  
  
  
4、系统提供的包DBMS_OUTPUT
Oracle8中,系统提供了一些包,这些包时在安装Oracle时自动安装的,用户可以直接使用。在内嵌包中有一个包经常用到--DBMS_OUTPUT,现在来简单地学习一下它。
内嵌包DBMS_OUTPUT用来输出PL/SQL变量的值。DBMS_OUTPUT包和其他系统包一样,都属于Oracle系统用户SYS内的对象。
  
  
PL/SQL之包的更多相关文章
- PL/SQL之--包
		
一.包 包是一组相关过程.函数.常量.变量.游标.异常等PL/SQL程序设计元素的组合.它类似于C++和Java中的类,其中变量相当于类中的成员变量,过程和函数相当于类中的方法.通过使用包,可以使开发 ...
 - PL/SQL编程—包
		
1.PLSQL 中的包就相当于java中的package,主要好处有(1)防止命名污染,(2)功能统一,(3)允许重载,(4)可以隐藏核心代码,(5)最重要的就是断开依赖链. 2.对于一个程序需要大量 ...
 - PL/SQL 09 包 package
		
--定义包头 create or replace package 包名as 变量.常量声明; 函数声明; 过程声明;end; --定义包体 create or replace package b ...
 - Insert BLOB && CLOB from PL/SQL and JDBC
		
For PL/SQL 1)Create Directory Where BLOB resides. create or replace directory temp as '/oradata2'; - ...
 - Oracle基础(五)pl/sql进阶(分页过程)
		
编写分页过程 通过pl/sql实现分页过程,再该过程中由简单到难一步步深入,目的在于通过该案例熟悉pl/sql的各种存储过程,包,游标.怎样在java中调用等内容的学习. 1.无返回值 ...
 - 使用集成SOA网关的PL / SQL中的REST
		
使用集成SOA网关的PL / SQL中的REST Oracle电子商务套件集成SOA网关(ISG)是一款开箱即用的模块,支持在Oracle Integration Repository中发布支持的接口 ...
 - Oracle PL/SQL入门之慨述
		
Oracle PL/SQL入门之慨述 一.PL/SQL出现的目的 结构化查询语言(Structured Query Language,简称SQL)是用来访问关系型数据库一种通用语言,它属于第四代语言( ...
 - PL/SQL -->隐式游标(SQL%FOUND)
		
PL/SQL -->隐式游标(SQL%FOUND) 分类: SQL/PLSQL 基础2010-12-22 16:23 4084人阅读 评论(0) 收藏 举报 sqlexceptionoracle ...
 - PL/SQL重新编译包无反应
		
前几天碰到一个有趣的事情:早上同事执行一个包很久没有反应,就中断了执行,发邮件让我帮忙查看具体情况,我用PL/SQL Developer登录后,找到这个包的过程中发现这个包的图标有红色叉叉,也就是说这 ...
 
随机推荐
- sql数据库 大小查询
			
select * from sys.master_files where name='CODA_PRD_Catalog' 12416*8/1024=(m)
 - 50余本中外Python电子教程及源码下载地址
			
链接:http://pan.baidu.com/s/1c0VTwsC 密码:hapu
 - CentOS运行C++语言的Hello World
			
1,编写代码,hello.cpp #include <iostream> using namespace std; int main(){ cout<<"hello ...
 - PHP消息队列实现
			
一个经典的消息队列就是这样的,主要是入队出队操作. shell脚本日志输出 学习地址:http://www.imooc.com/article/19111
 - 耗时 2 年,用 8.5 万块乐高积木最牛复刻 Apple Park
			
简评:国外大佬复刻 Apple Park,看了一下细节,确实厉害!只有你想不到,没有乐高拼不起来的,有没有乐高大神挑战一下? 苹果公园以各种各样的方式鼓舞人心,让人感兴趣.从建筑.可持续性和成本,到像 ...
 - 我把阿里云centos gcc从4.4.7升级到4.8.2的经历
			
我有试着去手动编译安装gcc,可是make的速度实在太慢,最后还直接失败了. 最后在csdn找到了个博客,说是使用yum来安装,网址为: http://blog.csdn.net/ppdouble/a ...
 - 2016级算法期末上机-C.简单·Bamboo's Fight with DDLs III
			
简单·Bamboo's Fight with DDLs III 分析 一句话:贪心,简单哈夫曼应用,要求的其实是所有结点的值与权值的乘积之和,也就是带权路径长. 可以理解为非叶子节点的权值的和,这里的 ...
 - C#-WebForm-★★★JQuery-动画★★★
			
1.show(),hide() 瞬间显示或隐藏,隐藏后不占有位置 2.slideDown(),slideUp() 向下拉伸显示,向上缩减隐藏 3.fadeIn(),fadeOut() 渐显或渐隐,隐藏 ...
 - Swagger2使用记录
			
1. Swagger2使用记录 1.1. Bean配置文件 @Configuration public class Swagger2 { @Bean public Docket createRestA ...
 - Java 子类父类构造方法执行顺序
			
public class Test { class Super { int flag = 1; Super() { test(); } void test() { System.out.println ...