亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

ORACLE中查找定位表最后DML操作的時間小結

2024-08-29 14:01:22
字體:
來源:轉載
供稿:網友

在Oracle數據庫中,如何查找,定位一張表最后一次的DML操作的時間呢? 方式有三種,不過都有一些局限性,下面簡單的解析、總結一下。

1:使用ORA_ROWSCN偽列獲取表最后的DML時間

   ORA_ROWSCN偽列是Oracle 10g開始引入的,可以查詢表中記錄最后變更的SCN。然后通過SCN_TO_TIMESTAMP函數可以將SCN轉換為時間戳,從而找到最后DML操作時SCN的對應時間。但是,默認情況下,每行記錄的ORA_ROWSCN是基于Block的,除非在建表的時候開啟行級跟蹤。

SELECT MAX(ORA_ROWSCN), SCN_TO_TIMESTAMP(MAX(ORA_ROWSCN)) FROM xxx.xxx;

如下所示,我們可以創建一個表TEST,然后查一查TEST表最后的DML的操作時間。如下所示:

SQL> CREATE TABLE TEST.TEST ( ID NUMBER); Table created. SQL> COL OWNER FOR A12;SQL> COL TABLE_NAME FOR A32;SQL> COL MONITORING FOR A32;SQL> SELECT OWNER, TABLE_NAME, MONITORING  2 FROM DBA_TABLES  3 WHERE OWNER='TEST'  4 AND TABLE_NAME='TEST';OWNER  TABLE_NAME      MONITORING------------ -------------------------------- --------------------------------TEST   TEST        YESSQL> INSERT INTO TEST.TEST VALUES(1);1 row created.SQL> COMMIT;Commit complete.SQL> SELECT sysdate FROM DUAL;SYSDATE-------------------2018-11-19 14:34:12SQL> SELECT MAX(ORA_ROWSCN), SCN_TO_TIMESTAMP(MAX(ORA_ROWSCN)) FROM TEST.TEST;MAX(ORA_ROWSCN) SCN_TO_TIMESTAMP(MAX(ORA_ROWSCN))--------------- --------------------------------------------------------------  52782810 19-NOV-18 02.34.03.000000000 PMSQL>

使用ORA_ROWSCN偽列獲取表最新的DML時間,也有一些不足和缺陷,具體如下所示:

1:使用SCN_TO_TIMESTAMP(MAX(ORA_ROWSCN))獲取表最后的DML操作時,有可能會遇到ORA-08181錯誤。

 $ oerr ora 8181
08181, 00000, "specified number is not a valid system change number"
// *Cause: supplied scn was beyond the bounds of a valid scn.
// *Action: use a valid scn.

SCN和時間戳的這種轉換要依賴于數據庫內部的數據記錄,而這些數據記錄就來自SMON_SCN_TIME基表,具體來說,SMON_SCN_TIME基表用于記錄過去時間段中SCN(system change number)與具體的時間戳(timestamp)之間的映射關系,因為是采樣記錄這種映射關系,所以SMON_SCN_TIME可以較為粗糙地(不精確地)定位某個SCN的時間信息。實際的SMON_SCN_TIME是一張簇表。而且從10g開始SMON也會定期清理SMON_SCN_TIME中的記錄,所以對于比較久遠的SCN則不能轉換。也就出現了數據庫某些表使用SCN_TO_TIMESTAMP函數時,會遇到ORA-08181錯誤,如下所示,我們用比基表SMON_SCN_TIME中MIN(SCN)的還小1的SCN做轉換時,就會遇到ORA-08181這個錯誤。

ORACLE,定位表,DML

根據官方文檔來看: SMON進程每5分鐘采集一次插入到SMON_SCN_TIME表中,同時也刪除一些歷史數據(超過5天前數據)

This is expected behavior as the SCN must be no older than 5 days as part of the current flashback database
features.
 
Currently, the flashback query feature keeps track of times up to a
maximum of 5 days. This period reflects server uptime, not wall-clock
time. You must record the SCN yourself at the time of interest, such as
before doing a DELETE.

2: 使用ORA_ROWSCN偽列獲取表中某一行的DML操作時間可能不準確,當然對于獲取表最后的DML時間是準確的。

    默認情況下,每行記錄的ORA_ROWSCN是基于數據塊(block)的,這樣對于某一行最后的DML時間是不準確的,除非在建表的時候執行開啟行級跟蹤(create table … rowdependencies),這樣才會是在行級記錄級別的SCN。而每個數據塊(block)在頭部是記錄了該數據塊(block)最近事務的SCN,所以默認情況下,只需要從塊的頭部直接獲取這個值就可以了,不需要其他任何的開銷。但是這明顯是不精確的,一個數據塊(block)中會有很多行記錄,每次事務不可能影響到整個數據塊(block)中所有的行,所以這是一個非常不精準的估算值,同一個數據塊(block)的所有記錄的ORA_ROWSCN都會是相同的.如下實驗所示, 當然對于獲取表最后的DML時間是準確的。所以對于每一行的ORA_ROWSCN要求精確的話,就必須開啟行級跟蹤。

 SQL> SELECT * FROM TEST.TEST;  ID----------   1SQL> SELECT ID, SCN_TO_TIMESTAMP(ORA_ROWSCN) FROM TEST.TEST;  ID SCN_TO_TIMESTAMP(ORA_ROWSCN)---------- -------------------------------------------------------------------   1 19-NOV-18 02.34.03.000000000 PMSQL> INSERT INTO TEST.TEST VALUES(2);1 row created.SQL> COMMIT;Commit complete.SQL> INSERT INTO TEST.TEST VALUES(3);1 row created.SQL> COMMIT;Commit complete.SQL> SELECT ID, SCN_TO_TIMESTAMP(ORA_ROWSCN) FROM TEST.TEST;  ID SCN_TO_TIMESTAMP(ORA_ROWSCN)---------- ---------------------------------------------------------------   1 19-NOV-18 03.41.01.000000000 PM   2 19-NOV-18 03.41.01.000000000 PM   3 19-NOV-18 03.41.01.000000000 PM

ORACLE,定位表,DML

3:假如表的數據被TRUNCATE掉或全部DELETE后,也會導致無法定位最后一次DML操作的時間。如下所示:

ORACLE,定位表,DML

2:使用DBA_TAB_MODIFICATIONS來查找、定為最后的DML操作時間

DBA_TAB_MODIFICATIONS describes modifications to all tables in the database that have been modified since the last time statistics were gathered on the tables

This view is populated only for tables with the MONITORING attribute. It is intended for statistics collection over a long period of time. For performance reasons, the Oracle Database does not populate this view immediately when the actual modifications occur. Run the FLUSH_DATABASE_MONITORING_INFO procedure in the DIMS_STATS PL/SQL package to populate this view with the latest information. The ANALYZE_ANY system privilege is required to run this procedure.

使用DBA_TAB_MODIFICATIONS來查看表最后DML的操作時間,如下測試所示

SQL> CREATE TABLE TEST.TEST (ID NUMBER);Table created.SQL> COL OWNER FOR A12;SQL> COL TABLE_NAME FOR A32;SQL> COL MONITORING FOR A32;SQL> SELECT OWNER, TABLE_NAME, MONITORING  2 FROM DBA_TABLES  3 WHERE OWNER='TEST'  4 AND TABLE_NAME='TEST';OWNER  TABLE_NAME      MONITORING------------ -------------------------------- --------------------------------TEST   TEST        YESSQL> INSERT INTO TEST.TEST VALUES(1);1 row created.SQL> COMMIT;Commit complete.SQL> ALTER SESSION SET NLS_DATE_FORMAT="YYYY-MM-DD HH24:MI:SS";Session altered.SQL> SELECT INSERTS,UPDATES,DELETES,TRUNCATED,TIMESTAMP  2 FROM DBA_TAB_MODIFICATIONS  3 WHERE TABLE_NAME='TEST' AND TABLE_OWNER='TEST';no rows selectedSQL> EXEC DBMS_STATS.FLUSH_DATABASE_MONITORING_INFO;PL/SQL procedure successfully completed.SQL> SELECT INSERTS,UPDATES,DELETES,TRUNCATED,TIMESTAMP  2 FROM DBA_TAB_MODIFICATIONS  3 WHERE TABLE_NAME='TEST' AND TABLE_OWNER='TEST'; INSERTS UPDATES DELETES TRU TIMESTAMP---------- ---------- ---------- --- -------------------   1   0   0 NO 2018-11-20 10:34:24

但是用DBA_TAB_MODIFICATIONS來定位表最后的DML操作時間也有一定的局限性。如下所示,有些局限性會影響定位最后DML操作的時間的準確性。

1:如果表沒有設置MONITORING屬性,那么DBA_TAB_MODIFICATIONS視圖是不會收集相關表的數據的呢。 假如某張表之前沒有設置MONITORING屬性,那么無法查找最后一次DML操作的時間,設置MONITORING屬性后,DBA_TAB_MODIFICATIONS視圖里面收集的是這個設置時間點后面的DML操作時間。

2:需要執行EXEC DBMS_STATS.FLUSH_DATABASE_MONITORING_INFO后,視圖才會有數據。

3:DML操作不提交或回滾,也會記錄到視圖中。這樣就會導致數據不準確。

未提交情況:

ORACLE,定位表,DML

回滾情況:

ORACLE,定位表,DML

3:收集完統計信息(ANALYZE或dbms_stats包收集統計信息)后,視圖中相關表記錄會置空

SQL> SELECT INSERTS,UPDATES,DELETES,TRUNCATED,TIMESTAMP  2 FROM DBA_TAB_MODIFICATIONS  3 WHERE TABLE_NAME='TEST' AND TABLE_OWNER='TEST'; INSERTS UPDATES DELETES TRU TIMESTAMP---------- ---------- ---------- --- -------------------   6   0   4 YES 2018-11-20 13:14:08SQL> exec dbms_stats.gather_table_stats('TEST','TEST');PL/SQL procedure successfully completed.SQL> SELECT INSERTS,UPDATES,DELETES,TRUNCATED,TIMESTAMP  2 FROM DBA_TAB_MODIFICATIONS  3 WHERE TABLE_NAME='TEST' AND TABLE_OWNER='TEST';no rows selectedSQL>

4:CTAS建立的插入信息不會記錄。如下測試所示:

SQL> CREATE TABLE TEST.TEST1 2 AS 3 SELECT * FROM TEST.TEST;Table created.SQL> exec dbms_stats.flush_database_monitoring_info;PL/SQL procedure successfully completed.SQL> SELECT INSERTS,UPDATES,DELETES,TRUNCATED,TIMESTAMP  2 FROM DBA_TAB_MODIFICATIONS  3 WHERE TABLE_NAME='TEST1' AND TABLE_OWNER='TEST';no rows selected

5:DBMS_STATS.FLUSH_DATABASE_MONITORING_INFO收集數據會有幾秒的延時,這個時間只能接近最后DML時間,而不是精準的。

SQL> COL OWNER FOR A12;SQL> COL TABLE_NAME FOR A32;SQL> COL MONITORING FOR A32;SQL> SELECT OWNER, TABLE_NAME, MONITORING  2 FROM DBA_TABLES  3 WHERE OWNER='TEST'  4 AND TABLE_NAME='TEST1';OWNER  TABLE_NAME      MONITORING------------ -------------------------------- --------------------------------TEST   TEST1       YESSQL> SQL> SELECT SYSDATE FROM DUAL;SYSDATE-------------------2018-11-20 10:46:39SQL> INSERT INTO TEST.TEST VALUES(10);1 row created.SQL> SELECT SYSDATE FROM DUAL;SYSDATE-------------------2018-11-20 10:46:57SQL> COMMIT;Commit complete.SQL> SELECT SYSDATE FROM DUAL;SYSDATE-------------------2018-11-20 10:47:07SQL> exec dbms_stats.flush_database_monitoring_info;PL/SQL procedure successfully completed.SQL> SELECT INSERTS,UPDATES,DELETES,TRUNCATED,TIMESTAMP  2 FROM DBA_TAB_MODIFICATIONS  3 WHERE TABLE_NAME='TEST' AND TABLE_OWNER='TEST'; INSERTS UPDATES DELETES TRU TIMESTAMP---------- ---------- ---------- --- -------------------   3   0   0 NO 2018-11-20 10:47:13

ORACLE,定位表,DML

3:觸發器捕獲最后DML操作時間

使用觸發器捕獲DML操作的最后時間是最準確的,但是也是性能開銷最大的,不推薦使用。

總結

以上所述是小編給大家介紹的ORACLE中查找定位表最后DML操作的時間小結,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!


注:相關教程知識閱讀請移步到oracle教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品动漫一区二区| 日韩视频在线观看免费| 精品色蜜蜜精品视频在线观看| 午夜剧场成人观在线视频免费观看| 久久亚洲综合国产精品99麻豆精品福利| 日韩视频中文字幕| 91免费欧美精品| 亚洲一区二区三区毛片| 欧美成人免费视频| 日韩电影中文 亚洲精品乱码| 欧美猛交ⅹxxx乱大交视频| 精品久久久久久亚洲国产300| 日韩免费视频在线观看| 91精品国产91久久久久久| 伊人久久精品视频| 国产精品久久婷婷六月丁香| 日韩在线欧美在线国产在线| 激情懂色av一区av二区av| 成人在线播放av| 日韩av在线精品| www.99久久热国产日韩欧美.com| 97精品国产97久久久久久免费| 91精品国产免费久久久久久| 97免费视频在线播放| 日韩av在线网页| 国产拍精品一二三| 日韩电影中文 亚洲精品乱码| 欧美网站在线观看| 伊是香蕉大人久久| 97视频人免费观看| 日本精品视频在线播放| 国产精品第8页| 中文字幕日韩欧美| 成人日韩av在线| 久久福利网址导航| 欧美刺激性大交免费视频| 久久偷看各类女兵18女厕嘘嘘| 色天天综合狠狠色| 国产亚洲aⅴaaaaaa毛片| 日韩在线观看网站| 成人福利网站在线观看| 51午夜精品视频| 日韩专区中文字幕| 日韩视频在线一区| 亚洲a区在线视频| 成人久久久久久久| 日韩av在线一区| 久久免费精品视频| 欧美国产中文字幕| 久久精品99久久香蕉国产色戒| 日韩视频中文字幕| 亚洲天堂日韩电影| 亚洲精品国产精品久久清纯直播| 国产亚洲成精品久久| 欧美高清视频免费观看| 精品国产91久久久久久老师| 亚洲免费人成在线视频观看| 国产精品久久久亚洲| 欧美第一淫aaasss性| 国产午夜精品全部视频播放| 久久久人成影片一区二区三区观看| 久久久久久久香蕉网| 亚洲欧美日韩精品久久| 粉嫩老牛aⅴ一区二区三区| 亚洲最大的av网站| 中文字幕亚洲情99在线| 欧美成人在线免费| 亚洲人成电影在线观看天堂色| 国产亚洲欧美aaaa| 在线播放国产一区二区三区| 久久国产精品电影| 色婷婷综合久久久久| 国产91亚洲精品| 奇门遁甲1982国语版免费观看高清| 国产在线不卡精品| 久久久久北条麻妃免费看| 91sao在线观看国产| 国产日韩综合一区二区性色av| 97视频在线播放| 国外日韩电影在线观看| 欧美精品18videos性欧| 日韩在线观看免费av| 国产丝袜一区二区三区| 亚洲第一色中文字幕| 久久福利视频网| 日韩成人av在线播放| 精品视频久久久| 日韩精品中文字| 亚洲免费影视第一页| 国产精品99导航| 国产精品日韩在线| 欧美二区在线播放| 最近中文字幕日韩精品| 国产精品自产拍在线观| 亚洲最大福利视频网| 欧美电影第一页| 国产精品美乳在线观看| 第一福利永久视频精品| 国产精品三级网站| 亚洲性无码av在线| 亚洲欧美日本另类| 91深夜福利视频| 久久精品视频99| 九九久久久久99精品| 国内精品久久久久| 亚洲曰本av电影| 精品国产一区二区三区四区在线观看| 日韩精品视频免费在线观看| 一本色道久久综合狠狠躁篇的优点| 亚洲欧美日韩精品久久奇米色影视| 精品久久久视频| 久久国产精品影片| 国产成人精品久久亚洲高清不卡| 国产精品久久久久不卡| 精品国产乱码久久久久久天美| 久久国产精品久久久久| 欧美成人在线免费| 国产精品美女午夜av| 欧美性猛交xxxx乱大交极品| 欧美福利视频在线| 亚洲国产成人91精品| 欧美成人精品在线视频| 国产日本欧美在线观看| 成人免费淫片aa视频免费| 91天堂在线观看| 国产精品男女猛烈高潮激情| 另类图片亚洲另类| 性欧美亚洲xxxx乳在线观看| 亚洲欧美另类国产| 91福利视频在线观看| 亚洲色图日韩av| 欧美大片在线看免费观看| 91精品视频专区| 久久久久久国产| 日韩有码在线观看| 欧美精品第一页在线播放| 中文字幕精品一区二区精品| 欧美怡春院一区二区三区| 欧美黑人又粗大| 2020国产精品视频| 91免费精品国偷自产在线| 性日韩欧美在线视频| 91成人天堂久久成人| 成人黄色在线播放| 亚洲国产小视频| 九九九久久国产免费| 欧美国产日韩在线| 国产精品入口夜色视频大尺度| 欧美激情亚洲激情| 97视频国产在线| 日韩av大片免费看| 一个色综合导航| 精品亚洲永久免费精品| 日本久久91av| 久久久中精品2020中文| 成人a免费视频| 国产精品第100页| 精品偷拍各种wc美女嘘嘘| 26uuu日韩精品一区二区| 亚洲国产精品资源| 国产视频亚洲精品| 91午夜在线播放| 一区二区三区视频免费| 欧美日韩一区二区在线播放|