触发器
触发器的定义就是说某个条件成立的时候,你触发器里面所定义的语句就会被自动的执行。因此触发器不需要人为的去调用,也不能调用。
然后,触发器的触发条件其实在你定义的时候就已经设定好的了。这里面需要说明一下,触发器可以分为语句级触发器和行级触发器。详细的介绍可以参考网上的资料,简单的说就是语句级的触发器可以在某些语句执行前或执行后被触发。而行级触发器则是在定义的了触发的表中的行数据改变时就会被触发一次。
具体举例:
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的触发器是干什么的,怎么用?
触发器的主要作用是,实现由主键和外键所不能保证的复杂的参照完整性和数据一致性。
例如我们日常生活中常用的银行存储系统就应用了触发器机制:当我们在银行办理存款或是取款业务后,系统除了会记录我们的交易信息外,还会根据我们存入或取出的金额自动更新我们帐户的余额(存款 *** 作后增加帐户余额,取款 *** 作后减少帐户余额),当 *** 作中出现意外情况(如断电),系统还会回滚我们所做的 *** 作,以保证交易的完整性。
所以触发器是在对表进行插入、更新和删除 *** 作时自动执行的存储过程,同时它也具有事务的功能(整个 *** 作要么全部成功,要么全部失败)。
触发器的概念:\x0d\x0a触发器英文名trigger,是指数据库中为响应一个特殊表格中的某些事件而自动执行的程序代码。\x0d\x0a\x0d\x0a为什么要使用触发器:\x0d\x0a触发器通常在进行登录或者对表作修改时触发,可以作为登录验证或者数据监控。换句话说,触发器是用来管理数据库的,很少用来 *** 作数据。比如,我要知道谁在什么时候修改了Test表,修改了什么,就要使用触发器了。1. 基本概念\x0d\x0a触发器是特殊的存储过程,基于一个表创建,主要作用就是实现由主键和外键所不能保证的复杂的参照完整性和数据一致性。\x0d\x0a当触发器所保护的数据发生变化(update,insert,delete)后,自动运行以保证数据的完整性和正确性。通俗的说:通过一个动作(update,insert,delete)调用一个存储过程(触发器)。\x0d\x0a2. 类型\x0d\x0a(1)DML触发器\x0d\x0a在数据库中发生数据 *** 作语言(DML)事件时将启用。DML 事件包括在指定表或视图中修改数据的 INSERT 语句、UPDATE 语句或 DELETE 语句。DML 触发器可以查询其他表,还可以包含复杂的 T-SQL 语句。系统将触发器和触发它的语句作为可在触发器内回滚的单个事务对待,如果检测到错误(例如,磁盘空间不足),则整个事务即自动回滚。\x0d\x0a(2)DDL 触发器\x0d\x0aSQL Server 2005 的新增功能。当服务器或数据库中发生数据定义语言(DDL)事件时将调用这些触发器。但与DML触发器不同的是,它们不会为响应针对表或视图的UPDATE、INSERT或DELETE语句而激发,相反,它们会为响应多种数据定义语言(DDL)语句而激发。这些语句主要是以CREATE、ALTER和DROP开头的语句。DDL触发器可用于管理任务,例如审核和控制数据库 *** 作。\x0d\x0a 创建DML触发器\x0d\x0a1. 使用存储过程模板创建存储过程\x0d\x0a在【对象资源管理器】窗口中,展开“数据库”节点,再展开所选择的具体数据库节点,再展开“表”节点,右击要创建触发器的“表”,选择“新建触发器”命令,如图所示:\x0d\x0a在右侧查询编辑器中出现触发器设计模板,用户可以在此基础上编辑触发器,单击“执行”按钮,即可创建该触发器。\x0d\x0a\x0d\x0a2. 使用T-SQL语句创建表\x0d\x0aCREATE TRIGGER 触发器\x0d\x0aON 表名\x0d\x0aFOR[update,insert,delete ]\x0d\x0aAS SQL语句\x0d\x0a例9-6:创建基于表reader ,DELETE *** 作的触发器。\x0d\x0aUSE Library\x0d\x0aGO\x0d\x0aIF EXISTS(SELECT name FROM sysobjects\x0d\x0a WHERE name='reader_d' AND type='TR')\x0d\x0aDROP TRIGGER reader_d --如果已经存在触发器reader_d则删除\x0d\x0aGO\x0d\x0aCREATE TRIGGER reader_d --创建触发器\x0d\x0aON reader --基于表\x0d\x0aFOR DELETE --删除事件\x0d\x0aAS\x0d\x0aPRINT '数据被删除!'--执行显示输出\x0d\x0aGO\x0d\x0a 试试吧!\x0d\x0a应用:\x0d\x0aUSE Library\x0d\x0aGO\x0d\x0aDELETE reader\x0d\x0awhere Rname='aaa'\x0d\x0a执行结果:\x0d\x0a数据被删除!\x0d\x0a(所影响的行数为 1 行)\x0d\x0a例9-7:在表borrow中添加借阅信息记录时,得到该书的应还日期。\x0d\x0a说明:在表borrow中增加一个应还日期SReturnDate。\x0d\x0aUSE Library\x0d\x0aIF EXISTS (SELECT name FROM sysobjects\x0d\x0aWHERE name ='T_return_date' AND type='TR')\x0d\x0aDROP TRIGGER T_return_date\x0d\x0aGO\x0d\x0aCREATE TRIGGER T_return_date --创建触发器\x0d\x0aON Borrow --基于表borrow\x0d\x0aAfter INSERT --插入 *** 作\x0d\x0aAS\x0d\x0a--查询插入记录INSERTED中读者的类型\x0d\x0aDECLARE @type int,@dzbh char(10),@tsbh char(15)\x0d\x0aSET @dzbh=(SELECT RID FROM inserted)\x0d\x0aSET @tsbh=(SELECT BID FROM inserted)\x0d\x0aSELECT @type= TypeID\x0d\x0aFROM reader\x0d\x0aWHERE RID=(SELECT RID FROM inserted)--副本\x0d\x0a/*把Borrow表中的应还日期改为\x0d\x0a当前日期加上各类读者的借阅期限*/\x0d\x0aUPDATE Borrow SET SReturnDate=getdate()+\x0d\x0aCASE \x0d\x0a WHEN @type=1 THEN 90\x0d\x0a WHEN @type=2 THEN 60\x0d\x0a WHEN @type=3 THEN 30\x0d\x0aEND\x0d\x0aWHERE RID=@dzbh and BID=@tsbh\x0d\x0a应用:\x0d\x0aUSE Library\x0d\x0aINSERT INTO borrow(RID,BID) values('2000186010','TP85-08')\x0d\x0a查看记录:\x0d\x0a \x0d\x0a例9-8:在数据库Library中,当读者还书时,实际上要修改表brorrowinf中相应记录还期列的值,请计算出是否过期。\x0d\x0aUSE Library\x0d\x0aIF EXISTS(SELECT name FROM sysobjects\x0d\x0aWHERE name='T_fine_js' AND type='TR')\x0d\x0aDROP TRIGGER T_fine_js\x0d\x0aGO\x0d\x0aCREATE TRIGGER T_fine_js\x0d\x0aON borrow\x0d\x0aAfter UPDATE\x0d\x0aAS\x0d\x0aDECLARE @days int,@dzbh char(10),@tsbh char(15)\x0d\x0aSET @dzbh=(select RID from inserted)\x0d\x0aSET @tsbh=(select BID from inserted)\x0d\x0aSELECT @days=DATEDIFF(day, ReturnDate, SReturnDate)\x0d\x0a--DATEDIFF函数返回两个日期之差,单位为DAY\x0d\x0aFROM borrow\x0d\x0aWHERE RID=@dzbh and BID=@tsbh\x0d\x0aIF @days>0\x0d\x0a PRINT '没有过期!'\x0d\x0aELSE\x0d\x0a PRINT '过期'+convert(char(6),@days)+'天'\x0d\x0aGO\x0d\x0a应用:\x0d\x0aUSE Library\x0d\x0aUPDATE borrow SET ReturnDate='2007-12-12'\x0d\x0aWHERE RID='2000186010' and BID='TP85-08'\x0d\x0aGO\x0d\x0a执行结果:\x0d\x0a过期-157 天\x0d\x0a(1 行受影响)\x0d\x0a例9-9:对Library库中Reader表的 DELETE *** 作定义触发器。\x0d\x0aUSE Library\x0d\x0aGO\x0d\x0aIF EXISTS(SELECT name FROM sysobjects\x0d\x0a WHERE name='reader_d' AND type='TR')\x0d\x0aDROP TRIGGER reader_d\x0d\x0aGO\x0d\x0aCREATE TRIGGER reader_d\x0d\x0aON Reader\x0d\x0aFOR DELETE\x0d\x0aAS\x0d\x0aDECLARE @data_yj int\x0d\x0aSELECT @data_yj=Lendnum\x0d\x0aFROM deleted\x0d\x0aIF @data_yj>0\x0d\x0a BEGIN\x0d\x0a PRINT '该读者不能删除!还有'+convert(char(2),@data_yj)+'本书没还。\x0d\x0a ROLLBACK\x0d\x0a END\x0d\x0aELSE\x0d\x0a PRINT '该读者已被删除!'\x0d\x0aGO\x0d\x0a应用:\x0d\x0aUSE Library\x0d\x0aGO\x0d\x0aDELETE Reader WHERE RID='2005216119'\x0d\x0a执行结果:\x0d\x0a该读者不能删除!还有4 本书没还。\x0d\x0a 修改触发器\x0d\x0aALTER TRIGGER 触发器\x0d\x0a 删除触发器\x0d\x0aDROP TRIGGER 触发器\x0d\x0a 查看触发器\x0d\x0asp_helptext trigger_name\x0d\x0asp_helptrigger table_name欢迎分享,转载请注明来源:内存溢出
评论列表(0条)