zoukankan      html  css  js  c++  java
  • Oracle中用触发器实现自动记录表数据被修改的历史信息

    oracle中用触发器实现自动记录表数据被修改的历史信息

    有一些比较重要的表字段每次修改需要做历史记录,以后可以查询这个表中某些字段如何被修改过。由什么改成了什么等,由谁操作,操作时间等。

     实例:1.首先创建一个成绩表

    2.然后创建一个成绩修改日志表

     3.针对成绩表写一个触发器,在这里只写笔试成绩和面试成绩的修改触发,各位开发人员可根据自己需要添加修改触发器

     --面试成绩,以及笔试成绩修改记录触发器
    create or replace trigger "TR_EXAM_SCORE_UPDATE"
    before update on exam_score
    for each row

    begin
         
          if :old.facescore<>:new.facescore then
              insert into exam_scorelog values(seq_exam_scorelog.nextval,:old.examid,:old.studentid,:old.jobid,:old.courseid,'facescore','面试成绩', :old.facescore,:new.facescore,:new.createuser,sysdate);
          end if;
          if :old.writerscore<>:new.writerscore then
              insert into exam_scorelog values(seq_exam_scorelog.nextval,:old.examid,:old.studentid,:old.jobid,:old.courseid,'writerscore','笔试成绩', :old.writerscore,:new.writerscore,:new.createuser,sysdate);
          end if;
    end;

    4.这样我们在页面上修改考生的笔试或者面试成绩都会自动记录到日志表中。

    查询修改日志表:

    5.这样我们在知道考生id后就可以查到此考生的成绩修改记录,谁修改的,原值是多少,修改后的值是多少,操作时间

  • 相关阅读:
    STM32.ADC
    电源方案集
    什么叫二级域名
    android驱动学习---led实验
    Get,Post和Head具体解释
    Android 编码规范
    VC:当前不会命中断点,还没有为该文档载入不论什么符号
    经常使用的结构体
    【Facebook的UI开发框架React入门之九】button简单介绍(iOS平台)-goodmao
    记录遇到的ios下的bugs[废弃]
  • 原文地址:https://www.cnblogs.com/weiyi1314/p/6401523.html
Copyright © 2011-2022 走看看