Oracle入门基础(十二)一一储存过程及触发器
1.第一个存储过程
打印Hello World
调用存储过程:
1.exec sayhelloworld();
2.begin
			sayhelloworld();
			sayhelloworld();
		end;
	create or replace procedure sayhelloworld
	as
	   --说明部分
	begin
	   dbms_output.put_line('Hello World');
end;
2.带参数的存储过程
给指定的员工涨100,并且打印涨前和涨后的薪水
create or replace procedure raiseSalary(eno in number)
is
       --定义变量保存涨前的薪水
       psal emp.sal%type;
begin
       --得到涨前的薪水
       select sal into psal from emp where empno=eno;
       --涨100
       update emp set sal=sal+100 where empno=eno;
       --要不要commit?
       dbms_output.put_line('涨前:'||psal||'   涨后:'||(psal+100));
end raiseSalary;
3.存储函数
查询某个员工的年收入
create or replace function queryEmpIncome(eno in number)
return number
is
       --定义变量保存月薪和奖金
       psal emp.sal%type;
       pcomm emp.comm%type;
begin
       --得到月薪和奖金
       select sal,comm into psal,pcomm from emp where empno=eno; 
   --返回年收入
   return psal*12+nvl(pcomm,0);
end queryEmpIncome;
4.out参数
–查询某个员工的姓名 薪水和职位
/*
1、查询某个员工的所有信息 —> out参数太多
2、查询某个部门中的所有员工信息 ----> 返回的是集合
*/
create or replace procedure queryEmpInformation(eno in number,
                                                pename out varchar2,
                                                psal   out number,
                                                pjob   out varchar2)
is
begin
   select ename,sal,job into pename,psal,pjob from emp where empno=eno;                                             
end queryEmpInformation;
5.在out参数中使用光标
查询某个部门中的所有员工信息 ----> 返回的是集合
create or replace package mypackage is
   type empcursor is ref cursor;
   procedure queryEmpList(dno in number,empList out empcursor);
end mypackage;
create or replace package body mypackage is
   procedure queryEmpList(dno in number,empList out empcursor)
   as
   begin
      open empList for select * from emp where deptno=dno;
   end;
end mypackage;
6.第一个触发器
每当成功插入新员工后,自动打印“成功插入新员工”
create trigger firsttrigger
after insert
on emp
declare
begin
  dbms_output.put_line('成功插入新员工');
end;
触发器应用一
实施复杂的安全性检查
禁止在非工作时间 插入新员工
1、周末:  to_char(sysdate,‘day’) in (‘星期六’,‘星期日’)
2、上班前 下班后:to_number(to_char(sysdate,‘hh24’)) not between 9 and 17
create or replace trigger securityemp
before insert
on emp
begin
   if to_char(sysdate,'day') in ('星期六','星期日','星期五') or
      to_number(to_char(sysdate,'hh24')) not between 9 and 17 then
      --禁止insert
      raise_application_error(-20001,'禁止在非工作时间插入新员工');
   end if;
end securityemp;
触发器应用二
/*
数据的确认
涨后的薪水不能少于涨前的薪水
create or replace trigger checksalary
before update
on emp
for each row
begin
    --if 涨后的薪水 < 涨前的薪水 then
    if :new.sal < :old.sal then
       raise_application_error(-20002,'涨后的薪水不能少于涨前的薪水。涨前:'||:old.sal||'   涨后:'||:new.sal);
end if;
  end checksalary;
												
											Oracle入门基础(十二)一一储存过程及触发器的更多相关文章
- Oracle入门基础(二)一一过滤和排序
		
SQL> --查询10号部门的员工 SQL> select * from emp where deptno=10; EMPNO ENAME JOB MGR HIREDATE SAL COM ...
 - MyBatis基础入门《十二》删除数据 - @Param参数
		
MyBatis基础入门<十二>删除数据 - @Param参数 描述: 删除数据,这里使用了@Param这个注解,其实在代码中,不使用这个注解也可以的.只是为了学习这个@Param注解,为此 ...
 - Java基础十二--多态是成员的特点
		
Java基础十二--多态是成员的特点 一.特点 1,成员变量. 编译和运行都参考等号的左边. 覆盖只发生在函数上,和变量没关系. Fu f = new Zi();System.out.println( ...
 - Bootstrap <基础十二>下拉菜单(Dropdowns)
		
Bootstrap 下拉菜单.下拉菜单是可切换的,是以列表格式显示链接的上下文菜单.这可以通过与 下拉菜单(Dropdown) JavaScript 插件 的互动来实现. 如需使用下列菜单,只需要在 ...
 - 无废话ExtJs 入门教程十二[下拉列表联动:Combobox_Two]
		
无废话ExtJs 入门教程十二[下拉列表联动:Combobox_Two] extjs技术交流,欢迎加群(201926085) 不管是几级下拉列表的联动实现本质上都是根据某个下拉列表的变化,去动态加载其 ...
 - Bootstrap入门(十二)组件6:导航标签页
		
Bootstrap入门(十二)组件6:导航标签页 1.标签页 2.胶囊式标签页 3.垂直展示 4.两端对齐的标签页 5.禁用的链接 6.添加下拉菜单 先引入本地的CSS文件和JS文件(注:1. ...
 - Python入门基础学习 二
		
Python入门基础学习 二 猜数字小游戏进阶版 修改建议: 猜错的时候程序可以给出提示,告诉用户猜测的数字偏大还是偏小: 没运行一次程序只能猜测一次,应该提供多次机会给用户猜测: 每次运行程序,答案 ...
 - UWP入门(十二)--数据绑定用法
		
原文:UWP入门(十二)--数据绑定用法 主要几个元素: Template DataTemplate ItemSource 数据绑定是一个数据提取的方法,能使数据和UI上的控件紧密相连,下面的Demo ...
 - RabbitMQ入门教程(十二):消息确认Ack
		
原文:RabbitMQ入门教程(十二):消息确认Ack 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csd ...
 
随机推荐
- Python中from … import …语句
			
from - import -语句可以让你从模块中导入一个指定的部分到当前模块
 - 【axios三部曲】一、使用axios
			
axios作为一个基于promise的网络请求库,它同时支持浏览器和node环境,是我们开发中常用的一个库  它的一些特性: 从浏览器发出XMLHttpRequests 从node.js发出http ...
 - python-利用xlrd模块中读取有合并单元格的excel数据
			
前言 对于excel中有合并单元格的情况,合并的单元格只能取到第一个单元格的值,合并的单元格后面的单元格内容的值为空,针对这个情况,写了下面一段代码实现, 对单元格进行判断,如果是传入的索引是合并单元 ...
 - 想上BI系统,原来的Excel优秀模板都丢弃吗?
			
我们公司之前一直都用Excel来存储数据,展示数据,Excel本身拥有强大的公式可以帮助我们的数据进行再加工计算,Excel的图形我们可以可以直接拿来展示数据,Excel本身还有数据透视表帮助我们的分 ...
 - 简单excel饼状图怎么做,bi工具怎么做饼状图
			
饼状图是为了在一个整体体现个体所占的比例,比如一块蛋糕每人各分多大份.了解了饼状图的含义,就来学习饼状图怎么做吧. 首先,我们准备excel表格饼状图的初始数据 然后选择excel表格上方的插入,选择 ...
 - 【windows 访问控制】十、词汇列表和对应C#类、枚举、命名空间
			
principals:主体 主体包含标识(identity 对用来来说就是用户名,对程序来说就是SID)和用户角色(role 对用户来说就是 组名 对程序来说就是组SID)subject:主体.主语i ...
 - Qt:QDir
			
0.说明 QDir提供了访问目录及目录下内容的类. QDir既可以用于访问文件系统,也可以用于访问Qt 资源系统(Qt's resource system.). Qt用 "/" 作 ...
 - c语言 排序(转)
			
https://blog.csdn.net/Galaxy_n/article/details/116742537
 - DateTime TryParse方法,介绍
			
1.与Date.Parse()方法的区别:Date.Parse(object o)方法接受一个object类型的参数,当参数为空或转换失败时会抛出异常DateTime.TryParse方法不会抛出异常 ...
 - js websocket断线重连
			
js websocket断开重连实例代码,请根据自己需求做出相应改动Vue中使用websocket $(function() { var lockReconnect = false;//避免重复连接 ...