Небольшой тест для определения, как в dba_tab_modifications отображается результат оператора MERGE
1. Для того, что бы результаты оказались в dba_tab_modifications нужно вызвать DBMS_STATS.FLUSH_DATABASE_MONITORING_INFO();
2. Сбор статистики по таблице убирает (удаляет) строчку из dba_tab_modifications.
3. MERGE учитывается по отдельности, как будто это 2 оператора
Пример
DROP TABLE a PURGE;
CREATE TABLE a(a NUMBER, val VARCHAR2(10));
INSERT INTO a
SELECT LEVEL, LPAD('x', 10, 'x')
FROM dual
CONNECT BY LEVEL <= 100;
BEGIN
DBMS_STATS.FLUSH_DATABASE_MONITORING_INFO();
END;
/
SELECT table_name, inserts, updates, deletes FROM dba_tab_modifications t WHERE table_name = 'A';
MERGE INTO a
USING (
SELECT LEVEL + 75 a, LPAD('Z', 10, 'Z') val
FROM dual
CONNECT BY LEVEL <= 75
) t
ON (a.a = t.a)
WHEN MATCHED THEN UPDATE SET a.val = t.val
WHEN NOT MATCHED THEN INSERT VALUES (t.a, t.val);
BEGIN
DBMS_STATS.FLUSH_DATABASE_MONITORING_INFO();
END;
/
SELECT table_name, inserts, updates, deletes FROM dba_tab_modifications t WHERE table_name = 'A';
UPDATE a SET val = LPAD('x', 10, 'x') WHERE ROWNUM <=22;
BEGIN
DBMS_STATS.gather_table_stats(NULL, 'A');
END;
/
SELECT table_name, inserts, updates, deletes FROM dba_tab_modifications t WHERE table_name = 'A';
Результаты
SQL>
Table dropped
Table created
100 rows inserted
PL/SQL procedure successfully completed
TABLE_NAME INSERTS UPDATES DELETES
------------------------------ ---------- ---------- ----------
A 100 0 0
75 rows merged
PL/SQL procedure successfully completed
TABLE_NAME INSERTS UPDATES DELETES
------------------------------ ---------- ---------- ----------
A 150 25 0
22 rows updated
PL/SQL procedure successfully completed
TABLE_NAME INSERTS UPDATES DELETES
------------------------------ ---------- ---------- ----------
SQL>