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

  • 相关阅读:
    Tomcat基本使用
    XML、java解释XML、XML约束
    配置文件的读取
    jdbc操作数据库以及防止sql注入
    java中的枚举类
    maven阿里云中央仓库
    spring boot&&cloud干货系列
    数据库 锁机制
    MySql的优化步骤
    MYSQL 索引无效和索引有效的详细介绍
  • 原文地址:https://www.cnblogs.com/weiyi1314/p/6401523.html
Copyright © 2011-2022 走看看