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

Oracle SQL:Valg af data og partitionsnavn fra tabel og trunkering af partitioner

Takket være dit tip om rovid , jeg fandt en løsning. Hvis du har rækken, burde det være muligt at bestemme objektet rækken tilhører.

Et minimalt eksempel med 4 hash-partitioner:

CREATE TABLE pt (i NUMBER)
 PARTITION BY HASH (i) (PARTITION pt1, PARTITION pt2, PARTITION pt3, PARTITION pt4);

INSERT INTO pt SELECT ROWNUM FROM all_objects WHERE ROWNUM < 20;

Nu har hver række en ROWID . Du kan finde ud af objektnummeret via DBMS_ROWID.ROWID_OBJECT . Ordbogstabellen USER_OBJECTS har så objektnavnet (=navnet på tabellen) og underobjektnavnet (=navnet på partitionen):

SELECT i, 
       ROWID AS row_id, 
       dbms_rowid.rowid_object(ROWID) AS object_no,
       (SELECT subobject_name 
          FROM user_objects 
         WHERE object_id = dbms_rowid.rowid_object(pt.ROWID)) AS partition_name
  FROM pt
 ORDER BY 3;

I   ROW_ID              OBJECT_NO PARTITION_NAME
6   AAALrYAAEAAAATRAAA  47832   PT1
11  AAALrYAAEAAAATRAAB  47832   PT1
13  AAALrYAAEAAAATRAAC  47832   PT1
9   AAALrZAAEAAAATZAAA  47833   PT2
10  AAALrZAAEAAAATZAAB  47833   PT2
12  AAALrZAAEAAAATZAAC  47833   PT2
17  AAALrZAAEAAAATZAAD  47833   PT2
19  AAALrZAAEAAAATZAAE  47833   PT2
2   AAALraAAEAAAAThAAA  47834   PT3
5   AAALraAAEAAAAThAAB  47834   PT3
18  AAALraAAEAAAAThAAD  47834   PT3
8   AAALraAAEAAAAThAAC  47834   PT3
1   AAALrbAAEAAAATpAAA  47835   PT4
3   AAALrbAAEAAAATpAAB  47835   PT4
4   AAALrbAAEAAAATpAAC  47835   PT4
7   AAALrbAAEAAAATpAAD  47835   PT4


  1. php database billede viser problem

  2. Hvad er datatypen bytea, og hvornår vil jeg bruge den?

  3. Sådan krypteres en visning i SQL Server

  4. tæl antallet af Null-variabler pr. række mysql