本知识点仅适用于oracle 9i以上的版本。
查看表的数据变动情况请使用sql语句:select * from user_tab_modifications;
user_tab_modifications表的字段如下,从这个表中能够轻松找到表中做的修改,删除,增加记录的情况
注意以及使用方法:
1、但这张表不是实时更新的,默认情况15分钟更新一次,所以你更新一张表,可能在 user_tab_modifications里不能立刻体现出来。
2、想要实时查看也有办法实现,那就是在执行select * from user_tab_modifications之前先执行exec dbms_stats.flush_database_monitoring_info;这个存储过程目的就是立刻刷新异动信息的
3、当执行上面的存储过程出错时候,错误如下:
error at line 1:
ora-20000: insufficient privileges
ora-06512: at sys.dbms_stats, line 2148
ora-06512: at sys.dbms_stats, line 14135
ora-06512: at line 1
哈哈错误很明显,没有权限,那么提权!
4、为用户提权,,首先用管理员账号登陆,授予某个账户执行dbms_stats.flush_database_monitoring_info的权限。
grant analyze any to epplm(这里是你的用户名)
5、ok提权成功,那么返回到原账号(epplm),再执行exec dbms_stats.flush_database_monitoring_info,ok没问题
6、此时再执行select * from user_tab_modifications,记录出现了。
7、flush_database_monitoring_info存储过程之后,所有之前的操作都将被提交!
8、对于oracle10i以及以上的版本,dml操作,都可以在该表中查到,因为这个功能默认是开启的,如果没有开启,可以通过这个方法开启:alter table t monitoring;
存储过程:
create or replace procedure pro_analyze_and_tablemodify is
2begin
3 dbms_output.put_line('开始执行,过程很长,请等待');
4 dbms_stats.flush_database_monitoring_info;--立刻刷新
5 insert into tablemodifications select * from user_tab_modifications;--两个表结构一样
6 pro_analyzetables;--执行分析表(调用上一篇的存储过程)
7 dbms_output.put_line('执行成功');
8end pro_analyze_and_tablemodify;
