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

您所在的位置:网站首页 手动触发是什么意思 数据库触发器中new表和old表是什么意思

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

#数据库触发器中new表和old表是什么意思| 来源: 网络整理| 查看: 265

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

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

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

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

数据审计是触发器的重要功能,其作用是跟踪数据的变化过程,审核 *** 作的合法性与合理性,如果触发不合法的 *** 作,可依据审计的记录把数据恢复到原来的状态。

数据审计业务一般由两个数据表构成,一个是业务表,普通用户可以拥有此表读写权限;

一个是审计表,普通用户不拥有此表读写权限,只有超级用户才拥有此表读写权限,用于记录数据的变化过程。下面以一个案例的方式来说明数据审计的过程和作用。

有一个存储车辆收费信息表t_car,表结构如图车辆收费信息表结构所示,因业务要求,程序要有对该表的数据修改权限,为此需要审计对该表上数据的记录值修改信息,以备查询、跟踪。

车辆收费信息表结构

有一个审计表t_record,表结构如图审计表结构所示,要记录对车辆收费信息表的修改行为的所有信息,以供事后进行审计,判断 *** 作行为是否合法。

审计表存储的内容有修改前pay字段的值、修改后pay字段的值、记录被修改的时间、登录数据库服务器修改数据的ip地址、登录数据库服务器的账号信息。

审计表结构

((1)用auditsql脚本初始化数据表环境,然后使用触发器记录所有用户对表t_car进行UPDATE *** 作修改数据的行为。触发器代码如下:DELIMITER//DROPTRIGGERIFEXISTStri_t_car;CREATETRIGGERtri_t_carBEFOREUPDATEONt_carFOREACHROWBEGINIFNEWpayOLDpayTHENINSERTINTOt_record(username

1new与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 *** 作中:oldscore=60,表示update *** 作前score字段的旧值是60。

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

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

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

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

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

DELETE语句,只有old才合法;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

DELIMITER//DROPTRIGGERIFEXISTSt_exception_trigger;CREATETRIGGERt_exception_triggerAFTERINSERTONmytabFOREACHROWBEGIN--tab3表不存在

在Access 的帮助里可以查询到:触发器只支持Adp项目,

Mdb数据库可能不行,

关于触发器 (ADP)

全部显示

全部隐藏

注释 本主题中的信息仅适用于 Microsoft Access 项目 (adp)。

触发器的定义

触发器是一种特殊类型的存储过程,它在特定的表中使用数据修改 *** 作修改数据时才起作用,这些修改 *** 作有:UPDATE、INSERT、或 DELETE。触发器可以查询其他表而且可以包含复杂的 SQL 语句。这对于实施复杂的商业规则或要求尤其有用。例如,可依据顾客帐户的状态来控制是否允许插入订单。

触发器对于实施参照完整性也是有用的,参照完整性可使得在表中添加、更新或者删除行时保持表之间已定义的关系。然而,实施参照完整性的最佳方法是在相关表中定义主键和外键约束。如果使用数据库图表,就可以通过创建表之间的关系来自动创建一个外键约束。

使用触发器的优势

触发器在下述几个方面很有用:

触发器是自动的:在对表中的数据修改后(例如手动输入数据或应用程序 *** 作)立即激活触发器,例如手动输入数据或应用程序 *** 作。

触发器能够通过数据库中相关联的表实现级连修改。例如,可以对 titles 表的 title_id 列编写删除触发器,以删除其他表中的匹配行。触发器将 title_id 列用作唯一键,以定位 titleauthor、sales 和 roysched 表中的匹配行。

触发器能够实施比使用检查约束所定义限制更为复杂的限制。与检查约束不同,触发器可以引用其他表中的列。例如,触发器可以回滚试图对价格低于 $10 的书籍(保存在 titles 表中)应用折扣(保存在 discounts 表中)的更新。

以上就是关于数据库触发器中new表和old表是什么意思全部的内容,包括:数据库触发器中new表和old表是什么意思、数据库中触发器重要的功能是什么、数据库的触发器怎么进行高级 *** 作等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址:https://outofmemory.cn/sjk/9431003.html



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3