Oracle数据库中的函数,包和触发器

php中文网
发布: 2016-06-07 17:32:22
原创
1112人浏览过

在pL/Sql developer工具左侧选择ldquo;Functionrdquo;,右键新建就行。在弹出的框中输入函数名和返回值(返回值是必须的),参数

函数:

函数和存储过程非常的相似,唯一的不同就是函数具有返回值。而存储过程是没有返回值的。

函数的定义:

在pL/Sql developer工具左侧选择“Function”,右键新建就行。在弹出的框中输入函数名和返回值(返回值是必须的),参数可以不写。定义如下,创建一个无参的函数:

/**
函数和存储过程非常的相似,唯一的不同的就是函数有返回值。
**/

create or replace function firstFun return varchar2
is
 
begin
  return 'Hello World';
end firstFun;

创建一个有参数的函数:

/**
  计算年薪是多少?
**/
create or replace function paramFun(salary number) return  number
is
 
begin
  return salary*12;
end paramFun;

在begin中的写法和存储过程一样。
函数的运行和存储过程的一样。

包的介绍:

包的组成:

包头(package):包头部分申明包内数据类型,,常量,变量,游标,子程序和异常错误处理,这些元素为包的公有元素。

包主体(package body):包主体则是包定义部分的具体实现,它负责为包头中所声明子程序提供具体的实现,在包主体中还可以声明包的私有元素。

包头和包主体分开编译,并作为两个分开的对象分别存放在数据库字典中。

创建方法:

启科网络PHP商城系统
启科网络PHP商城系统

启科网络商城系统由启科网络技术开发团队完全自主开发,使用国内最流行高效的PHP程序语言,并用小巧的MySql作为数据库服务器,并且使用Smarty引擎来分离网站程序与前端设计代码,让建立的网站可以自由制作个性化的页面。 系统使用标签作为数据调用格式,网站前台开发人员只要简单学习系统标签功能和使用方法,将标签设置在制作的HTML模板中进行对网站数据、内容、信息等的调用,即可建设出美观、个性的网站。

启科网络PHP商城系统 0
查看详情 启科网络PHP商城系统

在开发工具PL/SQL Developer左侧有Packages右键点击新建。输入name值,创建包。会出现两个编辑框。一个是头一个是主体,区别图标不一样。

一个简单的入门案例:

/**
  这里是包头,主要是对数据的定义
**/
create or replace package firstPack is
  --定义一个变量
  v_bonus number:=200;
--定义一个函数
  function yearSalary(salary number) return number;
  --定义一个存储过程
  procedure myrop;
 
end firstPack;

 

/**
包主体:对申明的实现
计算年薪
年薪=月薪*12+奖金
**/
create or replace package body firstPack is

--对包头申明函数的实现
 function yearSalary(salary number) return number
  is
  begin
    return salary*12+v_bonus;--这里用到了前面申明的变量
  end;
--对存储过程的实现
 procedure myrop is
  begin
    --向学生表插入一条数据
          insert into tab_stu(stu_id,stu_name,stu_age,class_id) values(9,'凯南',21,2);
          commit;
  end;
end firstPack;

接下来请看第2页精彩内容

 

相关阅读:

Oracle触发器的使用

Oracle触发器给表自身的字段重新赋值出现ORA-04091异常

Oracle创建触发器调用含参数存储过程

Oracle触发器查询统计本表

MySQL 触发器应用案例

linux

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号