乐观 发表于 2015-1-16 14:19:22

TRIGGER 触发器取得insert, delete, update行的信息

2008年1月16号MySQLAB被Sun公司收购。而2009年,SUN又被Oracle收购。就这样如同一个轮回,MySQL成为了Oracle公司的另一个数据库项目。触发器语句中利用了两种特别的表:deleted表和inserted表。
Deleted表用于存储DELETE和UPDATE语句所影响的行的复本。在实行DELETE或UPDATE语句时,行从触发器表中删除,并传输到deleted表中。Deleted表和触发器表一般没有不异的行。
Inserted表用于存储INSERT和UPDATE语句所影响的行的正本。在一个拔出或更新事件处置中,新建行被同时增加到inserted表和触发器表中。Inserted表中的行是触发器表中新行的正本。
1.拔出操纵(Insert)
Inserted表无数据,Deleted表有数据
2.删除操纵(Delete)
Inserted表有数据,Deleted表无数据
3.更新操纵(Update)
Inserted表无数据(新数据),Deleted表无数据(旧数据)
因此我们的方案中要构造这种逆操作。Event_type增加一种FLASHBACK_EVENT。这类操作形式与Query_Event相同,都是简单的SQL语句,只是包含了将数据恢复的操作。

谁可相欹 发表于 2015-1-18 12:54:48

再开发调试阶段和OLAP环境中,外键是可以建立的。新版本中加入了SETNULL和SETDEFAULT属性,能够提供能好的级联设置。

活着的死人 发表于 2015-1-26 20:43:17

原来的计算字段其实和虚拟字段很像。只是管理方面好了而已,性能方面提高不多。但是SQL2005提供了计算字段的持久化,这就提高了查询的性能,但是会加重insert和update的负担。OLTP慎用。OLAP可以大规模使用。

因胸联盟 发表于 2015-2-4 21:26:25

SQLServer的异构移植功能个人感觉最好了。(如果对比过SQLServer的链接服务器和Oracle的透明网关的朋友会发现SQLServer的sp_addlinkedserver(openquery)异构数据库系列比Oracle真是强太多了。)

简单生活 发表于 2015-2-10 15:58:33

我个人认为就是孜孜不懈的学习

愤怒的大鸟 发表于 2015-3-10 19:40:05

无法深入到数据库系统层面去了解和探究

第二个灵魂 发表于 2015-3-17 10:11:38

但是随着数据量的增大,这种成本差距会逐渐减小,趋于相等。(500万数量级只相差10%左右)

山那边是海 发表于 2015-3-24 07:43:59

如安全管理、备份恢复、性能监控和调优等,SQL只要熟悉基本操作就可以,只要程序设计部分只要稍加了解即可(如存储过程、触发器等)。
页: [1]
查看完整版本: TRIGGER 触发器取得insert, delete, update行的信息