sql >> Database teknologi >  >> RDS >> Oracle

Oracle (11.2.0.1):Sådan identificeres rækken, som i øjeblikket er opdateret af UPDATE-sætningen

Du kan bruge forespørgslen til at overvåge langvarige DML-operationer og rollback. Hvis opdateringsfeltet ikke er inkluderet i indekset, er værdien af ​​used_urec feltet fra v$transaction visningen vil være meget tæt på antallet af rækker. Når opdateringshandlingen udføres, stiger disse værdier, hvis tilbagerulning udføres, reduceres værdierne til nul.

V$TRANSACTION lists the active transactions in the system.
    USED_UREC Number of undo records used
    USED_UBLK Number of undo blocks used
select
   substr(s.username,1,28) username,
   substr(s.program,1,25) program,
   s.command,
   t.used_urec,
   t.used_ublk,
   decode(s.command,
     0,'No Command',
     1,'Create Table',
     2,'Insert',
     3,'Select',
     6,'Update',
     7,'Delete',
     9,'Create Index',
     15,'Alter Table',
     21,'Create View',
     23,'Validate Index',
     35,'Alter Database',
     39,'Create Tablespace',
     41,'Drop Tablespace',
     40,'Alter Tablespace',
     53,'Drop User',
     62,'Analyze Table',
     63,'Analyze Index',
     s.command||': Other') command
from 
   v$session     s,
   v$process     p,
   v$transaction t
where s.paddr = p.addr
and s.taddr = t.addr 
order by 1

For eksempel 1. Hvis du opdaterer en kolonne, der ikke er indekseret, så er antallet af rækker 39915830 og USED_UREC 40000562 cirka sammenfaldende .

create table test_update(p1,p2,p3,p4 )
  PCTFREE     1
  INITRANS    1
  MAXTRANS    255
  TABLESPACE  arhiv_data
as 
SELECT a.n_p_u, a.id_reg, a.id_vag, a.vrsvop
  FROM a_vag_atr a;

SELECT count(*)
          FROM test_update a
==>
COUNT(*)                                     
-------------------------------------------- 
                                    39915830 

Session 1

update test_update 
set p2=1234567890
==>
39915830 row(s) updated

Session 2 start opdatering

USERNAME       PROGRAM         COMMAND  USED_UREC   USED_UBLK   COMMAND_1                                             
---------------- ---------------------- ------------------- --------------------
ASUDS          sqlnavigator.exe      6  4181959    62690           Update       

stop opdatering

USERNAME       PROGRAM         COMMAND  USED_UREC   USED_UBLK   COMMAND_1                                             
---------------- ---------------------- ------------------- --------------------
ASUDS          sqlnavigator.exe      6   40000562   601871       Update       

For eksempel 2. hvis du opdaterer det indekserede felt, så er antallet af linjer * 3 cirka USED_UREC. 39915830 *3=~116705429

create table test_update(p1,p2,p3,p4 )
  PCTFREE     1
  INITRANS    1
  MAXTRANS    255
  TABLESPACE  arhiv_data
as 
SELECT a.n_p_u, a.id_reg, a.id_vag, a.vrsvop
  FROM a_vag_atr a;

SELECT count(*) FROM test_update a
==>
COUNT(*)                                     
-------------------------------------------- 
                                    39915830 

CREATE INDEX test_ind ON test_update
  (
    p1                              ASC
  )

Session 1

update test_update 
set p1=12
==>
39915830 row(s) updated

Session 2stop opdatering

USERNAME       PROGRAM         COMMAND  USED_UREC   USED_UBLK   COMMAND_1                                             
---------------- ---------------------- ------------------- --------------------
ASUDS          sqlnavigator.exe      6  116705429   1392538        Update       

For eksempel 3. hvis du indsætter i en tabel, der ikke er indekseret, er antallet af rækker nøjagtigt USED_UREC.

create table test_update(p1,p2,p3,p4 )
      PCTFREE     1
      INITRANS    1
      MAXTRANS    255
      TABLESPACE  arhiv_data

 SELECT count(*)
              FROM test_update a
==>
    COUNT(*)                                     
    -------- 
          0

Session 1

declare
 i pls_integer:=1;
begin
for i in 1..500000 loop
insert into test_update(p1,p2,p3,p4)
values(1,2,3,sysdate); 
end loop;
end;

select count(*) from  test_update
==>
COUNT(*)                                     
----------- 
     500000

Session 2

USERNAME       PROGRAM         COMMAND  USED_UREC   USED_UBLK   COMMAND_1                                             
    ASUDS          sqlnavigator.exe      2     500000    5815    Insert

For eksempel 4. hvis du sletter fra en tabel, der ikke er indekseret, er antallet af rækker nøjagtigt USED_UREC.

Session 1

 SELECT count(*) FROM test_update a
    ==>
        COUNT(*)                                     
        -------- 
         500000
delete from  test_update
==>
500000 row(s) deleted

Session 2

    USERNAME       PROGRAM         COMMAND  USED_UREC   USED_UBLK   COMMAND_1                                             
---------------- ---------------------- ------------------- --------------------
        ASUDS      sqlnavigator.exe   7      500000      9616         Delete  


  1. hvordan man bruger dbms_scheduler til at køre jobbet hvert 30. minut

  2. Sammenlign strenge, der ignorerer accenter i SQL (ORACLE)

  3. Send flere værdier i en enkelt parameter

  4. Hvad er forskellen mellem Float og Numeric/Decimal i SQL Server - SQL Server / T-SQL Tutorial Del 33