Oracle数据库中有关触发器问题

Oracle数据库中有关触发器问题,第1张

触发器是一种特殊类型的存储过程 它不同于存储过程 触发器主要是通过事件进行触发而被执行的 触发器的触发事件分可为 类 分别是DML事件 DDL事件和数据库事件 而存储过程可以通过存储过程名字而被直接调用 当对某一表进行诸如UPDATE INSERT DELETE 这些 *** 作时 SQL Server 就会自动执行触发器所定义的SQL 语句 从而确保对数据的处理必须符合由这些SQL 语句所定义的规则

触发器是特定事件出现的时候 自动执行的代码块 类似于存储过程 但是用户不能直接调用他们

触发器功能

允许/限制对表的修改

自动生成派生列 比如自增字段

强制数据一致性

提供审计和日志记录

防止无效的事务处理

启用复杂的业务逻辑

触发器种类

触发器的种类可划分为 种 数据 *** 纵语言(DML)触发器 替代(INSTEAD OF)触发器 数据定义语言(DDL)触发器 数据库事件触发器

数据 *** 纵语言(DML)触发器 简称DML触发器 是定义在表上的触发器 创建在表上 由DML事件引发的触发器 编写DML触发器时的两点要素是 确定触发的表 即在其上定义触发器的表 确定触发的事件 DML触发器的触发事件有INSERT UPDATE和DELETE三种替代触发器 简称INSTEAD OF触发器 创建在视图上 用来替换对视图进行的删除 插入和修改 *** 作数据定义语言(DDL)触发器 简称DDL触发器 定义在模式上 触发事件是数据对象的创建和修改数据库事件触发器 定义在整个数据库或模式上 触发事件是数据库事件

ORACLE产生数据库触发器的语法为

CREATE [OR REPLACE] TRIGGER 触发器名

{BEFORE|AFTER|INSTEAD OF} 触发事件 [OR 触发事件 ]

ON 表名

WHEN 触发条件

[FOR EACH ROW]

DECLARE

声明部分

BEGIN

主体部分

END

其中

触发器名 触发器对象的名称 由于触发器是数据库自动执行的 因此该名称只是一个名称 没有实质的用途 一个触发器可由多个不同的数据 *** 纵语言 *** 作触发 在触发器中 可用INSERTING DELETING UPDATING谓词来区别不同的数据 *** 纵语言 *** 作 这些谓词可以在IF分支条件语句中作为判断条件来使用

触发时间 指明触发器何时执行 该值可取 触发的时间有BEFORE和AFTER两种 分别表示触发动作发生在DML语句执行之前和语句执行之后 确定触发级别 有语句级触发器和行级触发器两种 语句级触发器表示SQL语句只触发一次触发器 行级触发器表示SQL语句影响的每一行都要触发一次

Before 表示在数据库动作之前触发器执行在SQL语句的执行过程中 如果存在行级BEFORE触发器 则SQL语句在对每一行 *** 作之前 都要先执行一次行级BEFORE触发器 然后才对行进行 *** 作 如果存在行级AFTER触发器 则SQL语句在对每一行 *** 作之后 都要再执行一次行级AFTER触发器

after 表示在数据库动作之后出发器执行 如果存在语句级AFTER触发器 则在SQL语句执行完毕后 要最后执行一次语句级AFTER触发器

触发事件 指明哪些数据库动作会触发此触发器 指INSERT DELETE或UPDATE事件 事件可以并行出现 中间用OR连接

insert 数据库插入会触发此触发器

update 数据库修改会触发此触发器

delete 数据库删除会触发此触发器

表 名 数据库触发器所在的表

for each row 表示触发器为行级触发器 省略则为语句级触发器 对表的每一行触发器执行一次

触发器的创建者或具有DROP ANY TIRGGER系统权限的人才能删除触发器 删除触发器的语法如下

DROP TIRGGER 触发器名

可以通过命令设置触发器的可用状态 使其暂时关闭或重新打开 即当触发器暂时不用时 可以将其置成无效状态 在使用时重新打开 该命令语法如下

ALTER TRIGGER 触发器名 {DISABLE|ENABLE}

其中 DISABLE表示使触发器失效 ENABLE表示使触发器生效

同存储过程类似 触发器可以用SHOW ERRORS 检查编译错误

如果有多个触发器被定义成为相同时间 相同事件触发 且最后定义的触发器是有效的 则最后定义的触发器被触发 其他触发器不执行 触发器体内禁止使用MIT ROLLBACK SAVEPOINT语句 也禁止直接或间接地调用含有上述语句的存储过程 定义一个触发器时要考虑上述多种情况 并根据具体的需要来决定触发器的种类

触发器的作用

触发器的主要作用就是其能够实现由主键和外键所不能保证的复杂的参照完整性和数据的一致性 除此之外 触发器还有其它许多不同的功能

( ) 强化约束(Enforce restriction)

触发器能够实现比CHECK 语句更为复杂的约束

( ) 跟踪变化Auditing changes

触发器可以侦测数据库内的 *** 作 从而不允许数据库中未经许可的指定更新和变化

( ) 级联运行(Cascaded operation)

触发器可以侦测数据库内的 *** 作 并自动地级联影响整个数据库的各项内容 例如 某个表上的触发器中包含有对另外一个表的数据 *** 作(如删除 更新 插入)而该 *** 作又导致该表上触发器被触发

( ) 存储过程的调用(Stored procedure invocation)

为了响应数据库更新触 发器可以调用一个或多个存储过程 甚至可以通过外部过程的调用而在DBMS( 数据库管理系统)本身之外进行 *** 作

由此可见 触发器可以解决高级形式的业务规则或复杂行为限制以及实现定制记录等一些方面的问题 例如 触发器能够找出某一表在数据修改前后状态发生的差异 并根据这种差异执行一定的处理 此外一个表的同一类型(INSERT UPDATE DELETE)的多个触发器能够对同一种数据 *** 作采取多种不同的处理

总体而言 触发器性能通常比较低

lishixinzhi/Article/program/Oracle/201311/18340

数据库 触发器有什么用

触发器

触发器的定义就是说某个条件成立的时候,你触发器里面所定义的语句就会被自动的执行。因此触发器不需要人为的去调用,也不能调用。

然后,触发器的触发条件其实在你定义的时候就已经设定好的了。这里面需要说明一下,触发器可以分为语句级触发器和行级触发器。详细的介绍可以参考网上的资料,简单的说就是语句级的触发器可以在某些语句执行前或执行后被触发。而行级触发器则是在定义的了触发的表中的行数据改变时就会被触发一次。

具体举例:

1. 在一个表中定义的语句级的触发器,当这个表被删除时,程序就会自动执行触发器里面定义的 *** 作过程。这个就是删除表的 *** 作就是触发器执行的条件了。

2. 在一个表中定义了行级的触发器,那当这个表中一行数据发生变化的时候,比如删除了一行记录,那触发器也会被自动执行了。

触发器简介:

触发器是一种特殊类型的过程。与普通过程不同的是,过程需要用户显式地调用才执行,而触发器则是当某些事件发生时,由Oracle自动执行。

触发器主要由如下几个部分组成:

触发事件:

触发条件:

触发对象:

触发 *** 作:

编写触发器时,需要注意以下几点:

触发器不接受参数。

一个表上最多可以有12个触发器,但同一时间、同一事件、同一类型的触发器只能有一个。还需要注意,各个触发器之间不能有矛盾。

在一个表上的触发器越多,对在该表上的DML *** 作性能影响就越大。

触发器最大为32KB。如果确实需要,可以先建立过程,然后在触发器中用CALL语句调用。

在DML触发器中只能使用DML语句(select,insert,update,delete)。

在系统触发器中只能包含DDL语句(create,alter,drop)。

触发器中不能包含事务控制语句(mit,rollback,savepoint)。因为触发器是触发语句的一部门,触发语句被提交或回退时,触发器也就被提交或回退了。

在触发器主体中调用的任何过程、函数都不能使用事务控制语句。

在触发器主体中不能声明任何long和blob变量。新值new、旧值old也不能指向表中的任何long和blog列

不同类型的触发器(如DML触发器、INSTEAD OF触发器、系统触发器)的语法格式和作用都有较大区别。

SQL中,触发器是什么?

1、触发器。 定义: 何为触发器?在SQL Server里面也就是对某一个表的一定的 *** 作,触发某种条件,从而执行的一段程序。触发器是一个特殊的存储过程。 常见的触发器有三种:分别应用于Insert , Update , Delete 事件。(SQL Server 2000定义了新的触发器,这里不提) 我为什么要使用触发器?比如,这么两个表: Create Table Student( --学生表 StudentID int primary key, --学号 .... ) Create Table BorrowRecord( --学生借书记录表 BorrowRecord int identity(1,1), --流水号 StudentID int , --学号 BorrowDate datetime, --借出时间 ReturnDAte Datetime, --归还时间 ... ) 用到的功能有: 1.如果我更改了学生的学号,我希望他的借书记录仍然与这个学生相关(也就是同时更改借书记录表的学号)2.如果该学生已经毕业,我希望删除他的学号的同时,也删除它的借书记录。 等等。 这时候可以用到触发器。对于1,创建一个Update触发器: Create Trigger truStudent On Student for Update ------------------------------------------------------- --Name:truStudent --func:更新BorrowRecord 的StudentID,与Student同步。 --Use :None --User:System --Author: 懒虫 # SapphireStudio ( chair3) --Date : 2003-4-16 --Memo : 临时写写的,给大家作个Sample。没有调试阿。 ------------------------------------------------------- As if Update(StudentID) begin Update BorrowRecord Set br.StudentID=i.StudentID From BorrowRecord br , Deleted d ,Inserted i Where br.StudentID=d.StudentID end 理解触发器里面的两个临时的表:Deleted , Inserted 。注意Deleted 与Inserted分别表示......>>

请问数据库 触发器有什么用

我就给你解释一下实际场景吧

比如你有两个表 A 和 B

A表有ID 和 NAME两列

B表有ID,PLAY,NAMEID三列,A与B没有关联

如果你想删除B表的内容,但是又同时想删除A表中A.ID=B.NAMEID

那么你就要写两条语句

如果使用触发器

就只用写删除B表的内容语句,一旦删除内容,则触发器设定的表规则被触发,那么A表的相关内容也一起删除了

SQL中触发器有什么作用

当你对表进行了添删改查等 *** 作时,如果你需要做一些特定的业务 *** 作,就可以使用触发器。

顾名思义,触发,当你做了某种预设的 *** 作时才会执行触发器的命令

举个例子。。

假设你有个员工基础信息表,里面有员工的身份z号码,手机等基本信息。。

那么,当你换了身份z或手机,需要修改号码的时候,肯定是去修改员工的基础资料表。

假设你现在有别的地方,比如人事档案啊之类的,同样使用了员工的手机等信息。。难道你还要再去修改一次档案表么。。那么如果还有其他地方使用了呢?

而触发器就可以在这种时候做出判断,如果修改了基础表的信息,那么就同步把其他使用了基础表信息的地方也更改成最新的信息。。

大概就是这么个意思。。当然还有其他的作用

数据库中替代触发器的定义是什么 5分

(1)DML触发器:是指触发器在数据库中发生数据 *** 作语言(DML)事件时将启用。DML事件即指在表或视图中修改数据的insert、update、delete语句也。 (2)DDL触发器:是指当服务器或数据库中发生数据定义语言(DDL)事件时将启用。DDL事件即指在表或索引中...

数据库中的触发器重点在什么地方?

简单来讲哪就是事件触发。

比如你对数据库中的表进行了一个插删等 *** 作,你想在你即将做或者完成这个 *** 作的时候程序能自动做一点别的工作,比如你想对插入数据检查一下或者对删除后的数据总数进行一下统计。

本来哪,你可以把这个工作写在自己的程序里,就是把检查写在你插入动作之前或者把统计数目写在删除动作之后。这样的问题是:你要做插删的时候就都要写这些代码,而且很容易就遗漏了。

而触发器哪,你定义在某个 *** 作上,比如把那个检查的工作过程定义成插入的前触发器,把统计工作定义成后触发器,那么在你进行插入删除的时候,数据库那边的程序就自动的给你做了这个工作了。

主要作用哪:我感觉

一是完整性(防止自己编程的遗漏),

二是简单,

三是由数据库程序(比如Oracle)进行这项工作,而不是由你自己的程序做,效率高。

下面是人家的一些教程,其实道理是很简单的。你可以用它后面讲的几个数据库的例子,自己写一个,试试就知道了。

————————————————————————————————————————

一 触发器介绍

触发器是一种特殊的存储过程,它在插入,删除或修改特定表中

的数据时触发执行,它比数据库本身标准的功能有更精细和更复杂的

数据控制能力。数据库触发器有以下的作用:

* 安全性。可以基于数据库的值使用户具有 *** 作数据库的某种权

利。

# 可以基于时间限制用户的 *** 作,例如不允许下班后和节假日

修改数据库数据。

# 可以基于数据库中的数据限制用户的 *** 作,例如不允许股票

的价格的升幅一次超过10%。

* 审计。可以跟踪用户对数据库的 *** 作。

# 审计用户 *** 作数据库的语句。

# 把用户对数据库的更新写入审计表。

* 实现复杂的数据完整性规则。

# 实现非标准的数据完整性检查和约束。触发器可产生比规则

更为复杂的限制。与规则不同,触发器可以引用列或数据库对

象。例如,触发器可回退任何企图吃进超过自己保证金的期货。

# 提供可变的缺省值。

* 实现复杂的非标准的数据库相关完整性规则。触发器可以对数

据库中相关的表进行连环更新。例如,在auths表author_code列上的

删除触发器可导致相应删除在其它表中的与之匹配的行。

# 在修改或删除时级联修改或删除其它表中的与之匹配的行。

# 在修改或删除时把其它表中的与之匹配的行设成NULL值。

# 在修改或删除时把其它表中的与之匹配的行级联设成缺省值。

# 触发器能够拒绝或回退那些破坏相关完整性的变化,取消试

图进行数据更新的事务。当插入一个与其主健不匹配的外部键

时,这种触发器会起作用。例如,可以在books.author_code

列上生成一个插入触发器,如果新值与auths.author_code列

中的某值不匹配时,插入被回退。

* 同步实时地复制表中的数据。

* 自动计算数据值,如果数据的值达到了一定的要求,则进行特

定的处理。例如,如果公司的帐号上的资金低于5万元则立即给财务人

员发送警告数据。

ORACLE与SYBASE数据库的触发器有一定的区别,下面将分别讲述

这两种数据库触发器的作用和写法。

二 ORACLE 触发器

ORACLE产生数据库触发器的语法为......>>

数据库触发器中new表和old表是什么意思?

顾名思义,new是新插入的数据,old是原来的数据

insert只会有new,代表着要插入的新记录

delete只会有old,代表着要删除的记录

update由于执行的是先删除旧的记录,再插入新的记录,因此new和old都会有,且含义与上面的相同

SQL数据库中的触发器怎么写啊?急

CREATE TRIGGER trig_stu_update ON student

FOR UPDATE

AS

begin

end

CREATE TRIGGER trig_stu_delete O功 student

FOR DELETE

AS

begin

end

------------------

上面是更新、删除的触发器模板,将你的代码填在begin...end之间。

触发器中经常用到的inserted,deleted。

inserted里面存放了insert、update *** 作的插入值或更新后值。

deleted里存放的是update、delete *** 作的更新前值或删除值。

使用方法:

declare @no int,@sex bit,@age int

--insert、update取新值

select @no=no,@sex=sex,@age=age from inserted

--delete、update删除值

select @no=no,@sex=sex,@age=age from deleted

sql的触发器是干什么的,怎么用?

触发器的主要作用是,实现由主键和外键所不能保证的复杂的参照完整性和数据一致性。

例如我们日常生活中常用的银行存储系统就应用了触发器机制:当我们在银行办理存款或是取款业务后,系统除了会记录我们的交易信息外,还会根据我们存入或取出的金额自动更新我们帐户的余额(存款 *** 作后增加帐户余额,取款 *** 作后减少帐户余额),当 *** 作中出现意外情况(如断电),系统还会回滚我们所做的 *** 作,以保证交易的完整性。

所以触发器是在对表进行插入、更新和删除 *** 作时自动执行的存储过程,同时它也具有事务的功能(整个 *** 作要么全部成功,要么全部失败)。

1.new与old在数据库的触发器中经常会用到更新前的值和更新后的值,所以掌握new和old的语法很重要。

old:表示 *** 作执行前的数据行。

new:表示 *** 作执行后的数据行。

一User数据表如图User数据表所示,若执行以下更新 *** 作语句:updateUsersetscore=80whereuser_id=1

User数据表

则在此 *** 作中,old表示未执行update语句前user_id=1这行记录;而new表示执行update语句后user_id=1这行记录。

从上面的表述中可知,new与old均表示某一行记录,old所表示的是写 *** 作发生前的这一行旧数据,new则表示写 *** 作发生后的这一行新的数据。正因如此,可以把new与old看作面向对象编程里面的一个对象或实例,与面向对象的方式类似,可用new.字段名或old.字段名的方式进行存取值。

old.字段名:表示未执行 *** 作前的该行对应的某字段值。

new.字段名:表示执行 *** 作后的该行对应的某字段值。

在上面User表的update *** 作中:old.score=60,表示update *** 作前score字段的旧值是60。

new.score=80,表示update *** 作后score字段的新值是80。

如果要使用new语句进行赋值,只能在before类型的触发器中使用,不能在after类型的触发器中使用。

更新 *** 作前使用before先赋值,再插入数据库中。如以下语句是正确的:CREATETRIGGERupdatepriceBEFOREinsertONconsumeinfoFOREACHROWBEGINsetnew.金额=0END更新 *** 作后,不能在after中用new赋值,因为 *** 作已经结束,只能读取内容。如以下语句是错误的:CEATETRIGGERupdatepriceAFTERinsertONconsumeinfoFOREACHROWBEGINsetnew.金额=0ENDnew与old的区别:前者可在before触发器中赋值、取值,也可在after触发器中取值;

后者只能用于取值,因为赋值没有意义。

注意:INSERT语句,只有new合法;

DELETE语句,只有old才合法;

UPDATE语句,可以同时使用new和old。

2.before与afterbefore与after表示触发器触发的时间点是在写 *** 作开始之前,还是在写 *** 作完成后,正因为它们有时间点先后的问题,因此它们的功能与使用场合有非常大的差别。

(1)before((1)先完成触发 *** 作,再执行业务数据的增删改。

(2)触发的语句先于监视的业务语句。

(3)有机会影响即将发生的 *** 作。

2)after((1)先完成业务数据的增删改,再触发。

(2)触发的语句晚于监视的业务语句。

(3)无法影响前面的增删改动作。

3.异常处理MySQL现有版本中不支持自定义异常,当某处需要抛出异常时,可抛出一个系统异常(类似运行异常)。如故意往不存在的表中插入数据等方式来触发系统异常的抛出,当异常抛出时,本次正在执行的所有 *** 作会终止执行,并回滚所有数据到 *** 作发生前的状态。

在触发器中,需要抛出异常的场景有很多,以下两个方面较为普遍:((1)新进来的数据不符合业务逻辑。

例如,①仓库最大商品库存数为10,订单要求一次性购买数量20。

②银行账户上只有50元,想要支付100元的账单。

(2)权限不足,不允许 *** 作。

例如,①普通用户通过非法途径 *** 作核心资源表。

②在非工作日修改业务数据。4.触发器案例用mytab.sql脚本创建表环境,然后用下面语句创建触发器。当往mytab表添加记录时,触发器中将抛出异常,导致所有 *** 作终止,并回滚所有 *** 作的数据。

DELIMITER//DROPTRIGGERIFEXISTSt_exception_triggerCREATETRIGGERt_exception_triggerAFTERINSERTONmytabFOREACHROWBEGIN--tab3表不存在


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9386094.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-27
下一篇 2023-04-27

发表评论

登录后才能评论

评论列表(0条)

保存