• 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后就可以查到此考生的成绩修改记录,谁修改的,原值是多少,修改后的值是多少,操作时间

  • 相关阅读:
    00045_多态-转型
    js下载文件夹的解决方案
    b/s下载文件夹的解决方案
    web下载文件夹的解决方案
    jsp下载文件夹的解决方案
    php下载文件夹的解决方案
    asp.net下载文件夹的解决方案
    KindEditor 从word中复制内容带多张图片
    CKEditor 从word中复制内容带多张图片
    Web编辑器 从word中复制内容带多张图片
  • 原文地址:https://www.cnblogs.com/weiyi1314/p/6401523.html
Copyright © 2020-2023  润新知