Oracle 触发器学习笔记一
触发器名:触发器对象的名称。由于触发器是数据库自动执行的,因此该名称只是一个名称,没有实质的用途。
触发时间:指明触发器何时执行,该值可取:
before:表示在数据库动作之前触发器执行;
after:表示在数据库动作之后触发器执行。
触发事件:指明哪些数据库动作会触发此触发器:
insert:数据库插入会触发此触发器;
update:数据库修改会触发此触发器;
delete:数据库删除会触发此触发器。
表 名:数据库触发器所在的表。
for each row:对表的每一行触发器执行一次。如果没有这一选项,则只对整个表执行一次。
实例一:
create or replace trigger UpdateEleHealthCard
before insert ON hisapplicationform
--after insert or update on hisapplicationform
--after insert on hisapplicationform
for each row
DECLARE elehealthcardValue varchar2(100);
idwhere varchar2(100);
BEGIN
--错误赋值方式
--select new.HEALTHCARD into elehealthcard from dual;
-- select new.ID into idwhere from dual;
-- dbms_output.put_line('elehealthcard=='|| elehealthcard);
-- dbms_output.put_line('idwhere=='|| idwhere);
--方式一
:new.elehealthcard := :new.HEALTHCARD;
dbms_output.put_line('电子健康卡号:'|| :new.elehealthcard); --方式二 赋值方式
/* elehealthcardValue:=:new.HEALTHCARD;
idwhere:=:new.ID;
dbms_output.put_line('elehealthcard=='||elehealthcardValue);
dbms_output.put_line('id=='||idwhere);
--数据变更
update hisapplicationform set elehealthcard=elehealthcardValue where id=idwhere;*/ END;
实例二:
create or replace trigger INS_QS_QueueBusiness
before insert on QS_QUEUEBUSINESS
for each row
declare
nextid number;
begin
if :new.id is null or :new.id=0 then
select SEQUENCE_BUSINESS.NEXTVAL into nextid from dual;
:new.id := nextid;
end if;
end INS_QS_QueueBusiness;
实例三:
create or replace trigger INS_QS_US_Type
after insert or update on us_Type
for each row
declare --完成提交登记数据的同时,产生排队叫号队列数据
sBUSINESSID varchar2(5);
iQUEUEID integer;
iOldQueueID integer;
sPATNAME varchar2(50);
iPATID integer;
iSTUDYID integer;
sHISID varchar2(50);
dENROLDATE date;
icount integer;
sClinsitPat varchar2(20);
sPartOfCheck varchar2(100);
sPhotoNo varchar2(50);
iTotalFee FLOAT;
sSex varchar2(20);
sAge varchar2(20);
sLodgeSection varchar2(20);
sLodgeDoctor varchar2(20);
dBirth date; sSTATUS varchar2(10);
iSortno integer;--2009-10-13增加过号 oldDate date;
newDate date;
imaxID number;
iEndNo number;
dayhr number;
xflag number;
begin
select count(*) into icount from qs_queue;
if icount=0 then
return;
end if; --队列当前最大号初始化
select trunc(LASTINITDATE) into oldDate from QS_QUEUE where rownum=1; --上次登记日期,即系统日期的前一天
select trunc(sysdate) into newDate from dual; --数据库系统日期 iSTUDYID := :new.ID;
iQUEUEID := :new.ustype;
--iPATID := :new.Patientid;
sSTATUS := '已登记';
--检查号
--select to_date(enroldate,'yyyy-mm-dd'), cliisinpat,partofcheck,
-- into dENROLDATE,sClinsitPat,sPartOfCheck from us_studies where studyid= iStudyid; --登记日期
--select name,HisID into sPATNAME,sHISID from us_patient where patientid= iPATID;--患者姓名、HISID select a.name,a.HisID, a.patientid, b.cliisinpat,b.partofcheck,b.photono,
a.sex,to_date(a.birthdate,'yyyy-mm-dd'), b.age||b.ageunit as age,b.lodgesection,b.lodgedoctor,
b.totalfee,to_date(b.enroldate,'yyyy-mm-dd')
into sPATNAME,sHISID,iPATID, sClinsitPat, sPartOfCheck,sPhotoNo,
sSex,dBirth,sAge,sLodgeSection,sLodgeDoctor,iTotalFee,dENROLDATE
from us_patient a ,us_studies b
where a.patientid= b.patientid and b.studyid= iSTUDYID;--患者姓名、HISID if newDate>oldDate then--删除两天前的数据
begin
if dEnrolDate = newDate then --如果登记日期等于系统日期时,修改上次登记日期和最大队列号
begin
select MAXBUSIID2 into imaxID from QS_QUEUE where QUEUEID = :new.ustype;
if imaxID > 0 then
begin
update qs_queue set maxbusiid = MAXBUSIID2;
update qs_queue set MAXBUSIID2 = MAXBUSIID3;
update qs_queue set MAXBUSIID3 = STARTNO,LASTINITDATE=newDate,flag=0; --比较日期,初始化各队列的信息
end;
end if;
delete from QS_QUEUEBUSINESS where trunc(enroldate) <= trunc(newDate); --删除两天前的数据
end;
end if;
end;
end if; /* --add by yzl...同一天且分上下午( 13点以后约的从1开始 )..begin */
select to_number(to_char(sysdate,'hh24') ) into dayhr from dual; select flag into xflag from qs_queue where rownum=1; if (newDate=oldDate) and (dayhr>=13) and (xflag=0) then
begin
select MAXBUSIID2 into imaxID from QS_QUEUE where QUEUEID = :new.ustype;
if imaxID > 0 then
begin
update qs_queue set maxbusiid = MAXBUSIID2;
update qs_queue set MAXBUSIID2 = MAXBUSIID3;
update qs_queue set MAXBUSIID3 = STARTNO,flag=1; --比较日期,初始化各队列的信息
end;
end if;
delete from QS_QUEUEBUSINESS where trunc(enroldate) <= trunc(newDate); --删除两天前的数据
end;
end if;
/* --add by yzl...同一天且分上下午( 12点以后约的从1开始 ).. end */ --队列号为0时,退出
if :new.ustype = 0 then
return;
end if; --登记时,首先判断登记日期是不是数据库系统日期,如果是,则取MAXBUSIID为最大队列号,
--如果比数据库日期大一天,则取MAXBUSIID2,如果大两天,取MAXBUSIID3
if dENROLDATE = newDate then
begin
select MAXBUSIID2 ,ENDNO into imaxID,iEndNo from QS_QUEUE where QUEUEID = :new.ustype;
if imaxId = -1 then
update qs_queue set maxbusiid2 = startno, maxbusiid3 = startno ;
end if; select MAXBUSIID +1,ENDNO into imaxID,iEndNo from QS_QUEUE where QUEUEID = :new.ustype; --登记日期 = 数据库系统日期
end;
elsif dENROLDATE = newDate + 1 then
begin
select MAXBUSIID2 +1,ENDNO into imaxID,iEndNo from QS_QUEUE where QUEUEID = :new.ustype;--登记日期 = 数据库系统日期+1
end;
elsif dENROLDATE = newDate + 2 then
select MAXBUSIID3 +1,ENDNO into imaxID,iEndNo from QS_QUEUE where QUEUEID = :new.ustype;--登记日期 = 数据库系统日期+2
else
return;
end if;
--如果当前排队号大于最大排序号,退出
if imaxId <>0 and imaxID > iEndNo then
return;
end if; if inserting then
begin
--获得当前队列最大号,并更新队列表中最大值
if dENROLDATE = newDate then
begin
select MAXBUSIID into sBUSINESSID from QS_QUEUE where QUEUEID=:new.ustype;
update QS_QUEUE set MAXBUSIID = MAXBUSIID +1 where QUEUEID = :new.ustype;
end;
elsif dENROLDATE = newDate + 1 then
begin
select MAXBUSIID2 into sBUSINESSID from QS_QUEUE where QUEUEID=:new.ustype;
update QS_QUEUE set MAXBUSIID2 = MAXBUSIID2 +1 where QUEUEID = :new.ustype;
end;
elsif dENROLDATE = newDate + 2 then
begin
select MAXBUSIID3 into sBUSINESSID from QS_QUEUE where QUEUEID=:new.ustype;
update QS_QUEUE set MAXBUSIID3 = MAXBUSIID3 +1 where QUEUEID = :new.ustype;
end;
end if;
--数据插入叫号业务表
select to_date(enroldate || ' ' || enroltime, 'YYYY-MM-DD HH24:MI:SS') into dENROLDATE
from us_studies where studyid= iStudyid; --登记时间 insert into QS_QUEUEBUSINESS (BUSINESSID,QUEUEID,PATNAME,PATID,STUDYID,HISID,ENROLDATE,STATUS, Sortno,CLINSINPAT,partofcheck
,Photono,Sex,Age,Totalfee,Lodgesection, Lodgedoctor,Birthdate)
values(sBUSINESSID,iQUEUEID, sPATNAME,iPATID,iSTUDYID,sHISID,dENROLDATE,sSTATUS,sBUSINESSID,sClinsitPat,sPartOfCheck
,sPhotono,sSex,sAge,iTotalfee,sLodgesection,slodgeDoctor,dBirth);
end; elsif updating then
begin
--获得当前患者的旧的队列号
select queueid into iOldQueueID from QS_QUEUEBUSINESS where studyid = :old.id;
--如果更改了队列,则重新生成排队号
if iQueueid <> iOldQueueID then
begin
if dENROLDATE = newDate then
begin
select MAXBUSIID into sBUSINESSID from QS_QUEUE where QUEUEID=:new.ustype;
update QS_QUEUE set MAXBUSIID = MAXBUSIID +1 where QUEUEID = :new.ustype;
end;
elsif dENROLDATE = newDate + 1 then
begin
select MAXBUSIID2 into sBUSINESSID from QS_QUEUE where QUEUEID=:new.ustype;
update QS_QUEUE set MAXBUSIID2 = MAXBUSIID2 +1 where QUEUEID = :new.ustype;
end;
elsif dENROLDATE = newDate + 2 then
begin
select MAXBUSIID3 into sBUSINESSID from QS_QUEUE where QUEUEID=:new.ustype;
update QS_QUEUE set MAXBUSIID3 = MAXBUSIID3 +1 where QUEUEID = :new.ustype;
end;
end if;
end;
else
begin
select businessid into sBusinessId from qs_queuebusiness where studyid =:old.id;
select Sortno into iSortno from qs_queuebusiness where studyid =:old.id;--2009-10-13增加过号
end;
end if; select name,HisID into sPATNAME,sHISID from us_patient where patientid= :new.Patientid;--患者姓名、HISID
update QS_QUEUEBUSINESS set BUSINESSID=sBUSINESSID,SortNo=sBUSINESSID, QUEUEID = :new.ustype, PATNAME = sPATNAME where STUDYID = :old.id;
end;
end if; end INS_QS_US_Type;
Oracle 触发器学习笔记一的更多相关文章
- Oracle基础学习笔记
Oracle基础学习笔记 最近找到一份实习工作,有点头疼的是,有阶段性考核,这...,实际想想看,大学期间只学过数据库原理,并没有针对某一数据库管理系统而系统的学习,这正好是一个机会,于是乎用了三天时 ...
- Oracle RAC学习笔记:基本概念及入门
Oracle RAC学习笔记:基本概念及入门 2010年04月19日 10:39 来源:书童的博客 作者:书童 编辑:晓熊 [技术开发 技术文章] oracle 10g real applica ...
- Oracle RAC学习笔记01-集群理论
Oracle RAC学习笔记01-集群理论 1.集群相关理论概述 2.Oracle Clusterware 3.Oracle RAC 原理 写在前面: 最近一直在看张晓明的大话Oracle RAC,真 ...
- Oracle RAC学习笔记02-RAC维护工具集
Oracle RAC学习笔记02-RAC维护工具集 RAC维护工具集 1.节点层 2.网络层 3.集群层 4.应用层 本文实验环境: 10.2.0.5 Clusterware + RAC 11.2.0 ...
- [Oracle]OWI学习笔记--001
[Oracle]OWI学习笔记--001 在 OWI 的概念里面,最为重要的是 等待事件 和 等待时间. 等待事件发生时,需要通过 P1,P2,P3 查看具体的资源. 可以通过 v$session_w ...
- 触发器学习笔记(:new,:old用法)
触发器学习笔记(:new,:old用法) 触发器是数据库发生某个操作时自动运行的一类的程序 用于保持数据的完整性或记录数据库操作信息方面 触发器不能够被直接调用,只能够 ...
- 吴裕雄--天生自然ORACLE数据库学习笔记:过程、函数、触发器和包
create procedure pro_insertDept is begin ,'市场拓展部','JILIN'); --插入数据记录 commit; --提交数据 dbms_output.put_ ...
- Oracle cursor学习笔记
目录 一.oracle库缓存 1.1.库缓存简介 1.2.相关概念 1.3.库缓存结构 1.4.sql执行过程简介 二.oracle cursor 2.1.cursor分类 2.2.shared cu ...
- oracle 触发器学习
触发器使用教程和命名规范 目 录触发器使用教程和命名规范 11,触发器简介 12,触发器示例 23,触发器语法和功能 34,例一:行级触发器之一 45,例二:行级触发器之二 46,例三:INSTEA ...
随机推荐
- 等待数据库引擎恢复句柄失败 SqlServer2012安装时报错 Win10
上周,在一批Win10系统电脑上安装SqlServer 2012时,屡次发生报错,安装失败,显示的失败信息是:等待数据库引擎恢复句柄失败 如下图所示: 面对这样的错误,我的第一反应是百度,在百度上找了 ...
- AP注册
1.ac发现ap 两种模式:二层发现.三层发现 按ap与ac所处ip网段不同,可以把注册过程分为二层模式和三层模式: 两种模式均通过发送discovery报文进行,二层模式discovery报文仅在同 ...
- python基础知识(继承)
继承的基本语法 class Class(继承那个基类如果有多个基类用逗号隔开,如果没有就继承object): """ 类的帮助信息""" ...
- 如何写出优雅耐看的JavaScript代码
参考链接:https://segmentfault.com/a/1190000020444918?utm_medium=hao.caibaojian.com&utm_source=hao.ca ...
- vue ts ,vue使用typescript,三种组件传值方式
参考链接:https://juejin.im/post/5c55156f6fb9a049ef270541
- day29 元类及异常处理
元类及异常处理 元类 什么是元类 在python中,一切皆对象,对象是由类产生的,那么类是不是对象呢? 举例: class A: pass print(type(A)) # <class 'ty ...
- SpringBoot整合持久层技术-创建项目
新建项目 Pom.xml文件 <?xml version="1.0" encoding="UTF-8"?> <project xmlns=&q ...
- Linux 下使用 rar 进行压缩和解压缩
1. 下载安装文件 https://www.rarlab.com/download.htm 注意下载 64位的 2. 2019.8 时的下载命令为: wget https://www.rarlab. ...
- centos7 使用nginx + tornado + supervisor搭建服务
如何在Linux下部署一个简单的基于Nginx+Tornado+Supervisor的Python web服务. Tornado:官方介绍,是使用Python编写出来的一个极轻量级.高可伸缩性和非阻塞 ...
- drf框架的模块分析
请求模块 请求模块是个什么鬼 ''' 1.drf的request是在wsgi的request基础上再次封装 2.wsgi的request作为drf的request一个属性:_request 3.新的r ...