Oracle
 sql >> Baza danych >  >> RDS >> Oracle

Oracle Delete Statement:ile wierszy zostało usuniętych przez kaskadowe usuwanie

chociaż nie jest to możliwe w przypadku sql%rowcount, jest to możliwe, jeśli napiszesz kod wyzwalacza, ale oznacza to, że potrzebujesz wyzwalacza dla wszystkich tabel, które chcesz monitorować. Również wyzwalacze spowolniłyby nieco operacje.

np.:

SQL> select * from one;

        ID
----------
         1
         2

SQL> select * from child_of_one;

        ID       O_ID
---------- ----------
         1          1
         2          1
         3          1
         4          2
         5          2
         6          2
         7          2
         8          2

chcemy, aby specyfikacja pakietu zawierała tablicę tabel + liczniki:

SQL> create or replace package foo
  2  as
  3    type rowcount_tab is table of pls_integer index by varchar2(30);
  4    t_rowcount rowcount_tab;
  5  end foo;
  6  /

Package created.

chcemy, aby wyzwalacz w tabeli najwyższego poziomu zresetował te liczby do zera:

SQL> create or replace trigger one_biud
  2  before insert or update or delete
  3  on one
  4  declare
  5  begin
  6    foo.t_rowcount.delete;
  7  end;
  8  /

Trigger created.

zakłada to, że interesuje Cię tylko tablica z usunięciem z tabeli najwyższego poziomu. jeśli nie, potrzebujesz wyzwalacza dla każdej tabeli z foo.t_rowcount.delete('TABLE_NAME') zamiast tego.

teraz a after dla każdego wyzwalacza wiersza na każdej interesującej tabeli, aby ustawić tablice:

SQL> create or replace trigger one_aiudfer
  2  after insert or update or delete
  3  on one
  4  for each row
  5  declare
  6  begin
  7    if (foo.t_rowcount.exists('ONE'))
  8    then
  9      foo.t_rowcount('ONE') := nvl(foo.t_rowcount('ONE'), 0)+1;
 10    else
 11      foo.t_rowcount('ONE') := 1;
 12    end if;
 13  end;
 14  /

Trigger created.

SQL> create or replace trigger child_of_one_aiudfer
  2  after insert or update or delete
  3  on child_of_one
  4  for each row
  5  declare
  6  begin
  7    if (foo.t_rowcount.exists('CHILD_OF_ONE'))
  8    then
  9      foo.t_rowcount('CHILD_OF_ONE') := nvl(foo.t_rowcount('CHILD_OF_ONE'), 0)+1;
 10    else
 11      foo.t_rowcount('CHILD_OF_ONE') := 1;
 12    end if;
 13  end;
 14  /

Trigger created.

teraz, kiedy usuwamy lub cokolwiek:

SQL> delete from one where id = 1;

1 row deleted.

SQL> declare
  2    v_table varchar2(30);
  3  begin
  4    v_table := foo.t_rowcount.first;
  5    loop
  6       exit when v_table is null;
  7             dbms_output.put_line(v_table || ' ' || foo.t_rowcount(v_table) || ' rows');
  8             v_table := foo.t_rowcount.next(v_table);
  9     end loop;
 10  end;
 11  /
CHILD_OF_ONE 3 rows
ONE 1 rows

PL/SQL procedure successfully completed.

SQL> delete from one where id = 2;

1 row deleted.

SQL> declare
  2    v_table varchar2(30);
  3  begin
  4    v_table := foo.t_rowcount.first;
  5    loop
  6       exit when v_table is null;
  7             dbms_output.put_line(v_table || ' ' || foo.t_rowcount(v_table) || ' rows');
  8             v_table := foo.t_rowcount.next(v_table);
  9     end loop;
 10  end;
 11  /
CHILD_OF_ONE 5 rows
ONE 1 rows



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. ORA-00257:błąd archiwizatora. Połącz tylko wewnętrznie, aż do zwolnienia.

  2. Czy literał daty Oracle „[rrrr-mm-dd]” zawsze używa wzorca rrrr-mm-dd?

  3. Jak zmodyfikować typ danych w Oracle z istniejącymi wierszami w tabeli?

  4. Funkcja Oracle to_date. Potrzebna maska

  5. Jak usunąć zduplikowane wiersze w SQL?