zoukankan      html  css  js  c++  java
  • 创建日志表记录DML操作和DDL操作

    创建一个日志表,记录dept表的DML操作

    create table dept_log(logid number,type varchar2(50),logdate date,deptno number,dname varchar2(50),loc varchar2(50));

    create sequence dept_log_seq;

    create or replace trigger dept_update_trigger10

    before insert or update or delete

    on dept

    for each row

    begin

    if inserting then

    insert into dept_log(logid,type,logdate,deptno,dname,loc)

    values(dept_log_seq.nextval,'insert',sysdate,:new.deptno,:new.dname,:new.loc);

    elsif updating then

    insert into dept_log(logid,type,logdate,deptno,dname,loc)

    values(dept_log_seq.nextval,'update',sysdate,:new.deptno,:new.dname,:new.loc);

    else

    insert into dept_log(logid,type,logdate,deptno,dname,loc)

    values(dept_log_seq.nextval,'delete',sysdate,:old.deptno,:old.dname,:old.loc);

    end if;

    end;

    /

    DDL操作日志记录表创建脚本

    drop table object_log purge;

    drop sequence object_log_seq;

    create sequence object_log_seq;

    create table object_log(

    oid number constraint pk_okd primary key,

           username varchar2(50) not null,

           operatedate date not null,

           objecttype varchar2(50) not null,

           objectowner varchar2(50) not null);

    编写触发器实现对数据库对象操作的日志记录

    create or replace trigger object_trigger

    after create or drop or alter

    on database

    declare

    begin

    insert into scott.object_log VALUES

              (scott.object_log_seq.nextval,ora_login_user,sysdate,ora_dict_obj_type,ora_dict_obj_owner);

    end;

    /

  • 相关阅读:
    github入门到上传本地项目
    17-索引
    16-pymysql模块的使用
    15-可视化工具Navicat的使用
    C语言/C++知识
    Apk反编译那些事
    CTF基本常识
    WebView net::ERR_CLEARTEXT_NOT_PERMITTED&&net::ERR_INTERNET_DISCONNECTED
    测试
    zookeeper-3.4.5安装&3台机器安装之后 ./zkServer.sh status 之后会显示“Error contacting service. It is probably not running.”的解决办法
  • 原文地址:https://www.cnblogs.com/kawashibara/p/9047628.html
Copyright © 2011-2022 走看看