返回顶部
首页 > 资讯 > 数据库 >Oracle系列:(30)触发器
  • 822
分享到

Oracle系列:(30)触发器

2024-04-02 19:04:59 822人浏览 泡泡鱼
摘要

什么是触发器【Trigger】?不同的DML(select/update/delete/insert)操作,触发器能够进行一定的拦截,符合条件的操作方可操作基表;反之,不可操作基表。类似于java


什么是触发器【Trigger】?

不同的DML(select/update/delete/insert)操作,触发器能够进行一定的拦截,符合条件的操作方可操作基表;反之,不可操作基表。类似于javaweb中的Filter、Struts2中的Iterceptor。


为什么要用触发器?

如果没有触发器,那么DML所有操作,均可无限制地操作基表,这样一来,不符合业务需求。



创建语句级触发器insertEmpTrigger,当对表【emp】进行增加【insert】操作前【before】,显示"hello world"

create or replace trigger insertEmpTrigger
before
insert
on emp
begin
   dbms_output.put_line('hello world'); 
end;
/


删除触发器insertEmpTrigger,语法:drop trigger 触发器名

drop trigger insertEmpTrigger;


使用insert语句插入一条记录,引起insertEmpTrigger触发器工作

insert into emp(empno,ename) values(1234,'小明');


使用insert语句插入N条记录,引起insertEmpTrigger触发器工作

insert into emp 
select * from xxx_emp;


Oracle系列:(30)触发器

创建语句级触发器deleteEmpTrigger,当对表【emp】进行删除【delete】操作后【after】,显示"world hello"

create or replace trigger deleteEmpTrigger
before
delete
on emp
begin
   dbms_output.put_line('删除数据'); 
end;
/


使用delete语句删除一条记录,引起deleteEmpTrigger触发器工作

delete from emp where empno=7369;


使用delete语句删除N条记录,引起deleteEmpTrigger触发器工作

delete from emp where 1=1;

Oracle系列:(30)触发器

星期一到星期五,且9-20点能向数据库emp表插入数据,否则使用函数抛出异常,

语法:raise_application_error('-20000','例外原因')

create or replace trigger securityTrigger
before
insert
on emp
declare
   pday varchar2(20);
   phour number(2);
begin
  select to_char(sysdate,'day') into pday from dual;
  select to_char(sysdate,'hh34') into phour from dual;
  if pday in ('星期六','星期日') or phour not between 7 and 22 then
    raise_application_error('-20000','非工作时间,不能向emp表添加数据');
  end if;
end;
/


Oracle系列:(30)触发器


创建行级触发器checkSalaryTrigger,涨后工资这一列,确保大于涨前工资,语法:for each row/:new.sal/:old.sal

create or replace trigger checkSalaryTrigger
after
update of sal
on emp
for each row
begin
   if :new.sal <= :old.sal then
     raise_application_error('-20200','工资不能越长越低');
   end if;
end;
/


其中,需要注意的地方

(1)update of sal是对列的更新进行触发 

(2)for each row

(3):new和:old代表一行记录

(4)raise_application_error中-20000和-20200之间允许开发者自定义错误


Oracle系列:(30)触发器


删除触发器,表还在吗?

基表还在;触发器不会进回收站,直接彻底删除


将表丢到回收站,触发器还在吗?

触发器还在


当闪回表后,触发器会在吗?


彻底删除表,触发器会在吗?

原来的触发器也被删除了

新的同样的名字的表,是不是继承原来的触发器的

您可能感兴趣的文档:

--结束END--

本文标题: Oracle系列:(30)触发器

本文链接: https://lsjlt.com/news/42931.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Oracle系列:(30)触发器
    什么是触发器【Trigger】?不同的DML(select/update/delete/insert)操作,触发器能够进行一定的拦截,符合条件的操作方可操作基表;反之,不可操作基表。类似于Java...
    99+
    2024-04-02
  • SqlServer系列笔记——触发器
    触发器是一种特殊类型的存储过程,它不同于前面介绍过的一般的存储过程。一般的存储过程通过存储过程名称被直接调用,而触发器主要是通过事件进行触发而被执行。触发器是一个功能强大的工具,在表中数据发生变化时自动强制...
    99+
    2024-04-02
  • SqlServer系列笔记——触发器2
    一、创建一个简单的触发器触发器是一种特殊的存储过程,类似于事件函数,SQL Server 允许为 INSERT、UPDATE、DELETE 创建触发器,即当在表中插入、更新、删除记录时,触发一个或一...
    99+
    2024-04-02
  • oracle 触发器
    -- Create table a  触发器create table T_AC_TEST(  ID     ...
    99+
    2024-04-02
  • 8Python全栈之路系列之MySQL触发器
    Python全栈之路系列之MySQL触发器l对某个表进行增/删/改操作的前后如果希望触发某个特定的行为时,可以使用触发器,触发器用于定制用户对表的行进行增/删/改前后的行为。创建触发器基本语法插入前CREA...
    99+
    2024-04-02
  • Oracle中触发器(2)
       上一篇对触发器的一些基本知识有了了解,在这一篇操作进行验证before触发器[oracle@test ~]$ sqlplus / as sysdbaSQL> cre...
    99+
    2024-04-02
  • Oracle触发器详解
    Oracle触发器是一种数据库对象,它可以在特定的数据操作(如插入、更新或删除)发生时自动执行一段预定义的PL/SQL代码。触发器可...
    99+
    2024-04-09
    oracle
  • oracle触发器定时触发怎么配置
    在Oracle数据库中,可以使用触发器来定时触发某些操作。触发器可在以下情况下自动触发:在插入、更新或删除表中的数据时,或在满足某些...
    99+
    2023-08-09
    oracle
  • Oracle DML触发器和DDL触发器实例详解
    目录一、概念二、DML触发器2.1、语句触发器2.2、行级触发器2.3、DML触发器语法:2.4、触发器谓词:2.5、实例说明三、DDL 触发器3.1、DDL触发器语法3.2、DDL 事件3.3、可用属性3.4、实例说明...
    99+
    2023-03-13
    oracle 触发器 oracle触发器语句 oracle创建触发器语句
  • Oracle DML触发器和DDL触发器实例详解
    目录一、概念二、DML触发器2.1、语句触发器2.2、行级触发器2.3、DML触发器语法:2.4、触发器谓词:2.5、实例说明三、DDL 触发器3.1、DDL触发器语法3.2、DDL...
    99+
    2023-03-13
    oracle 触发器 oracle触发器语句 oracle创建触发器语句
  • Oracle DML触发器和DDL触发器怎么使用
    今天小编给大家分享一下Oracle DML触发器和DDL触发器怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧...
    99+
    2023-07-05
  • oracle触发器、序列、任务计划练习一例
    今天在闲暇时间练习了一下oracle任务计划,具体详情如下1.创建表 TBL_TIMEcreate table tbl_time( id number not&nb...
    99+
    2024-04-02
  • Oracle 笔记(九)、触发器
    1、触发器一旦创建就会立刻生效,有时可能需要临时禁用触发器,最常见的原因就是涉及数据加载。ALTER TRIGGER trigger_name [ENABLE | DISABLE];  ...
    99+
    2024-04-02
  • oracle触发器是什么
    本篇文章给大家分享的是有关oracle触发器是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Oracle触发器是什么呢? 首先我们来了解一...
    99+
    2024-04-02
  • Oracle中的触发器trigger
    触发器是指被隐含执行的存储过程 一、创建DML触发器(before/after) 1、行触发器: 当一个DML操作影响DB中的多行时,对于其中复合触发条件的每行均触发一次(for e...
    99+
    2024-04-02
  • Oracle 触发器详解(trigger)
    Oracle中的触发器是一种特殊的数据库对象,它是与表关联的一段PL/SQL代码,当特定的数据库操作发生时,触发器会自动执行这段代码...
    99+
    2023-09-20
    Oracle
  • Oracle触发器trigger详解
    Oracle触发器(Trigger)是一种特殊的数据库对象,可以在数据库中的某个事件发生时自动执行一系列的操作。触发器通常与数据库表...
    99+
    2023-08-15
    oracle
  • oracle触发器怎么做
    触发器是一种数据库对象,允许在insert、update或delete事件发生时自动执行操作。创建触发器:使用create trigger语句,指定触发器名称、事件类型、表名和...
    99+
    2024-05-21
    oracle sql语句
  • oracle触发器怎么写
    oracle 触发器是数据库对象,用于在特定事件(如插入、更新或删除)发生时执行业务规则或操作。创建触发器需按以下步骤进行:1. 创建触发器,指定名称、事件、表和 for each ro...
    99+
    2024-05-30
    oracle
  • 通过触发器和自增序列实现oracle自增ID
    create sequence seq_tablename        start with 1        increment by 1;  create or replace trigger tri_tablename_i...
    99+
    2019-01-19
    通过触发器和自增序列实现oracle自增ID
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作