加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Oracle 检查表的数据变动

发布时间:2020-12-12 13:36:57 所属栏目:百科 来源:网络整理
导读:本知识点仅适用于Oracle?9i以上的版本。 查看表的数据变动情况请使用SQL语句:select * from user_tab_modifications; user_tab_modifications表的字段如下,从这个表中能够轻松找到表中做的修改,删除,增加记录的情况 注意以及使用方法: 1、但这张表不是
create?or?replace?procedure?Pro_Analyze_And_TableModify?is

?

2begin3???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;

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

本知识点仅适用于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;

存储过程:

?

    推荐文章
      热点阅读