一、每行有改动,则触发更新modifytime

SQL> create table test(id int, name varchar(10), crdate date, udate date);

表已创建。

SQL>
SQL> create trigger tri_test_up
2 before update on test
3 for each row
4 begin
5 :new.udate := sysdate;
6 end;
7 /

触发器已创建

SQL>
SQL> insert into test values(100, 'zhang', date'2016-01-01', date'2016-01-01');

已创建 1 行。

SQL>
SQL> update test set name = 'xx';

已更新 1 行。

SQL>
SQL> alter session set nls_date_format='yyyy-mm-dd hh24:mi:ss';

会话已更改。

SQL>
SQL> select * from test;

ID NAME CRDATE UDATE
---------- -------------------- ------------------- -------------------
100 xx 2016-01-01 00:00:00 2017-09-25 10:39:39

SQL>
SQL> drop table test purge;

表已删除。

二、跨表更新modifytime触发器

create table m(mid int, modifytime date);
create table t(id int, mid int, c1 int, c2 int);
create table r(rid int, refid varchar(10), refname varchar(10));

insert into m(mid) select rownum from DUAL connect by rownum <=10;

insert into t(id,mid)
select rownum, mid from m, (select rownum from DUAL connect by rownum <= 10) x;

begin
insert into r(rid, refid, refname) values(1,'r1','XXX');
insert into r(rid, refid, refname) values(2,'r1','YYY');
insert into r(rid, refid, refname) values(3,'r1','ZZZ');

insert into r(rid, refid, refname) values(4,'r2','XXX');
insert into r(rid, refid, refname) values(5,'r2','YYY');
insert into r(rid, refid, refname) values(6,'r2','ZZZ');
insert into r(rid, refid, refname) values(7,'r2','XXX');
insert into r(rid, refid, refname) values(8,'r2','YYY');
insert into r(rid, refid, refname) values(9,'r2','ZZZ');
end;
/

update t set c1 = mod(dbms_random.value() * 10 + 1 ,2) + 3;
update t set c2 = mod(dbms_random.value() * 10 + 1 ,5) + 4;

create or replace trigger tri_r_update
before update on r
for each row
begin
update m
set modifytime = sysdate
where exists(select * from t where m.mid = t.mid and c1 = :new.rid);
update m
set modifytime = sysdate
where exists(select * from t where m.mid = t.mid and c2 = :new.rid);
end;
/

create index ix_t_c1 on t(mid,c1);
create index ix_t_c2 on t(mid,c2);

create index ix_m_mid on m (mid);

/*
select * from t where c2 = 9
select * from m
SELECT * FROM r
update r set refname = '099999' where rid = 9
update m set modifytime = null
*/

drop table m purge;
drop table t purge;
drop table r purge;

本表触发更新modifytime,跨表更新modifytime 触发器的更多相关文章

  1. Django之model联表:一对多、跨表操作,联表查询

    表结构概述 model.py : class Something(models.Model): name = models.CharField(max_length=32) class UserTyp ...

  2. MySQL把一个大表拆分多个表后,如何解决跨表查询效率问题

    大表分表后每个表的结构相同,可以用sql的union 比如a,b表结构相同可以通过union来联接 select * from aunion allselect * from bwhere.... 其 ...

  3. django(3) 一对多跨表查询、ajax、多对多

    1.一对多跨表查询获取数据的三种形式:对象.字典.元组 例:有host与business两张表,host与business的id字段关联,business在host表中的对象名是b,  通过查询hos ...

  4. django models的点查询/跨表查询/双下划线查询

    django models 在日常的编程中,我们需要建立数据库模型 而往往会用到表与表之间的关系,这就比单表取数据要复杂一些 在多表之间发生关系的情形下,我们如何利用models提供的API的特性获得 ...

  5. django orm 基于双下划线的跨表查询

    一..基于双下划线的跨表查询(join实现) key:正向查询按字段,反向查询按表明小写 1.一对多跨表查询 查询在跨表中可以有两种方式,正向查询就是关键字段在你要搜索的表,没有关键字段就是反向查询 ...

  6. Mysql跨表更新 多表update sql语句总结

    Mysql跨表更新一直是大家所关心的话题,本文介绍mysql多表 update在实践中几种不同的写法 假定我们有两张表,一张表为Product表存放产品信息,其中有产品价格列Price:另外一张表是P ...

  7. mysql 去重,跨表更新,跨表删除

    一.去重 1.查询出重复的记录 CREATE TABLE push_log_full_2013_10_30_tmp SELECT * FROM `push_log_full` WHERE time B ...

  8. Mysql跨表更新

    Mysql跨表更新一直是大家所关心的话题,本文介绍mysql多表 update在实践中几种不同的写法,需要的朋友可以参考下 假定我们有两张表,一张表为Product表存放产品信息,其中有产品价格列Pr ...

  9. update关联其他表批量更新数据-跨数据库-跨服务器Update时关联表条件更新

    1.有时在做项目时会有些期初数据更新,从老系统更新到新系统.如果用程序循环从老系统付给新系统. 2.有时在项目中需要同步程序,或者自动同步程序时会有大量数据更新就可能用到如下方法了. 3.为了做分析, ...

随机推荐

  1. 02函数-04-箭头函数(ES6)

    ES6新增的函数:Arrow Function,定义方式就是一个箭头 箭头函数相当于匿名函数,并且简化了函数定义,和匿名函数最大的区别在于其内部的this不再"乱跑",而是由上下文 ...

  2. 代码的鲁棒性:链表中倒数第k个结点

    输入一个链表,输出该链表中倒数第k个结点. 代码思路如下:两个指针,先让第一个指针和第二个指针都指向头结点,然后再让第一个指正走(k-1)步,到达第k个节点.然后两个指针同时往后移动,当第一个结点到达 ...

  3. OSGi-入门篇之生命周期层(03)

    前言 生命周期层在OSGi框架中属于模块层上面的一层,它的运作是建立在模块层的功能之上的.生命周期层一个主要的功能就是让你能够从外部管理应用或者建立能够自我管理的应用(或者两者的结合),并且给了应用本 ...

  4. Spring @RequestParam乱码问题

    在网上找了很多资料才找到解决的方法,通过URL传递命名参数,后台接收的却是乱码解决方法如下: 方法一:将接收的参数重新编码 @RequestMapping(value="/handle&qu ...

  5. java GUI编程二

    java基础学习总结--GUI编程(二) 一.事件监听 测试代码一: 1 package cn.javastudy.summary; 2 3 import java.awt.*; 4 import j ...

  6. Judge Route Circle

    Initially, there is a Robot at position (0, 0). Given a sequence of its moves, judge if this robot m ...

  7. myeclipse的快捷键

    ------------------------------------MyEclipse 快捷键1(CTRL)-------------------------------------Ctrl+1 ...

  8. Windows下MySQL5.6.21安装步骤

    01.把 mysql-advanced-5.6.17-winx64.zip 解压到自定义 D:\mysql-5.6.17-W64 或 D:\mysql-advanced-5.6.17-winx64 目 ...

  9. Python实战之列表简单练习

    ['__add__', '__class__', '__contains__', '__delattr__', '__delitem__', '__dir__', '__doc__', '__eq__ ...

  10. jquery系列教程4-事件操作全解

    点击打开: jquery系列教程1-选择器全解 jquery系列教程2-style样式操作全解 jquery系列教程3-DOM操作全解 jquery系列教程4-事件操作全解 jquery系列教程5-动 ...