Oracle
 sql >> Teknologi Basis Data >  >> RDS >> Oracle

Cara menemukan kolom kunci utama (atau unik) yang mendasarinya dari tampilan Oracle

Anda dapat menemukan informasi tersebut melalui tampilan user_dependencies:

SQL> CREATE TABLE t_a
  2  (   id number(7)
  3  ,   primary key(id)
  4  )
  5  /

Table created.

SQL> CREATE VIEW v_a AS SELECT * FROM t_a
  2  /

View created.

SQL> select c.constraint_name
  2    from user_dependencies d
  3       , all_constraints c
  4   where d.name = 'V_A'
  5     and d.referenced_type = 'TABLE'
  6     and d.referenced_link_name is null
  7     and d.referenced_owner = c.owner
  8     and d.referenced_name = c.table_name
  9     and c.constraint_type = 'P'
 10  /

CONSTRAINT_NAME
------------------------------
SYS_C0051559

1 row selected.

Salam,
Rob.

EDIT :Untuk kemungkinan nama kolom tampilan, Anda dapat menggunakan kueri ini. Perhatikan bahwa tidak ada jaminan bahwa kolom seperti itu ada dalam tampilan Anda.

SQL> select c.constraint_name
  2       , 'V_' || substr(c.table_name,3) || '.' || cc.column_name possible_view_column
  3    from user_dependencies d
  4       , all_constraints c
  5       , all_cons_columns cc
  6   where d.name = 'V_A'
  7     and d.referenced_type = 'TABLE'
  8     and d.referenced_link_name is null
  9     and d.referenced_owner = c.owner
 10     and d.referenced_name = c.table_name
 11     and c.constraint_type = 'P'
 12     and c.owner = cc.owner
 13     and c.constraint_name = cc.constraint_name
 14  /

CONSTRAINT_NAME                POSSIBLE_VIEW_COLUMN
------------------------------ -------------------------------------------------------------
SYS_C0051561                   V_A.ID

1 row selected.


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Tampilkan kolom tahun ini dan tahun sebelumnya di oracle

  2. Setara dengan 'printf' Oracle

  3. Bagaimana cara memanfaatkan WebDev.WebServer.exe (VS Web Server) di x64?

  4. Permintaan Zeppelin Oracle SQL berjalan lebih dulu

  5. Bagaimana cara memasukkan lebih dari satu partisi dalam satu pernyataan pilih di Oracle