विशिष्ट स्तंभ नामों वाली तालिकाओं के लिए Oracle डेटाबेस खोजें?


94

हमारे पास कई तालिकाओं के साथ एक बड़ा ओरेकल डेटाबेस है। क्या कोई ऐसा तरीका है जिससे मैं यह पता लगा सकता हूं कि कुछ कॉलम नामों के साथ कोई टेबल है या नहीं?

IE मुझे उन सभी तालिकाओं को दिखाएं जिनमें कॉलम हैं: id, fname, lname, address

विवरण मैं जोड़ना भूल गया: मुझे विभिन्न स्कीमाओं के माध्यम से खोज करने में सक्षम होना चाहिए। जो मुझे कनेक्ट करने के लिए उपयोग करना चाहिए वह उन तालिकाओं के स्वामी नहीं हैं जिनके माध्यम से मुझे खोज करने की आवश्यकता है।

जवाबों:


198

किसी विशेष स्तंभ के साथ सभी तालिकाओं को खोजने के लिए:

select owner, table_name from all_tab_columns where column_name = 'ID';

उन तालिकाओं को खोजने के लिए जिनमें कोई भी या सभी 4 कॉलम हैं:

select owner, table_name, column_name
from all_tab_columns
where column_name in ('ID', 'FNAME', 'LNAME', 'ADDRESS');

सभी 4 कॉलम वाले टेबल खोजने के लिए (कोई भी गायब नहीं है):

select owner, table_name
from all_tab_columns
where column_name in ('ID', 'FNAME', 'LNAME', 'ADDRESS')
group by owner, table_name
having count(*) = 4;

2
इस खोज को करने के लिए आपको संभवतः ALL_TAB_COLUMNS के बजाय DBA_TAB_COLUMNS का उपयोग करना चाहिए, यदि आप जिस उपयोगकर्ता के रूप में लॉग इन कर रहे हैं, उसके पास कुछ तालिकाओं तक पहुंच नहीं है।
जेफरी केम्प

यह सच है, लेकिन केवल तभी, जब आप जिस उपयोगकर्ता के रूप में जुड़े हुए हैं, वह किसी भी योग्य विशेषाधिकार का चयन करें।
टोनी एंड्रयूज

2
जोड़ें column_name+ likeयदि आप सटीक नाम के बारे में सुनिश्चित नहीं हैं:select owner, table_name, column_name from all_tab_columns where column_name like 'someField%';
माइक आर

10

जो डेटा आप चाहते हैं, वह "cols" मेटा-डेटा तालिका में है:

SELECT * FROM COLS WHERE COLUMN_NAME = 'id'

यह आपको उन तालिकाओं की एक सूची देगा जिनमें आपके इच्छित सभी कॉलम हैं:

select distinct
  C1.TABLE_NAME
from
  cols c1
  inner join
  cols c2
  on C1.TABLE_NAME = C2.TABLE_NAME
  inner join
  cols c3
  on C2.TABLE_NAME = C3.TABLE_NAME
  inner join
  cols c4
  on C3.TABLE_NAME = C4.TABLE_NAME  
  inner join
  tab t
  on T.TNAME = C1.TABLE_NAME
where T.TABTYPE = 'TABLE' --could be 'VIEW' if you wanted
  and upper(C1.COLUMN_NAME) like upper('%id%')
  and upper(C2.COLUMN_NAME) like upper('%fname%')
  and upper(C3.COLUMN_NAME) like upper('%lname%')
  and upper(C4.COLUMN_NAME) like upper('%address%')  

एक अलग स्कीमा में ऐसा करने के लिए, तालिका के सामने स्कीमा को निर्दिष्ट करें, जैसे कि

SELECT * FROM SCHEMA1.COLS WHERE COLUMN_NAME LIKE '%ID%';

यदि आप कई स्कीमा की खोजों को एक आउटपुट परिणाम में जोड़ना चाहते हैं, तो आप ऐसा कर सकते हैं:

SELECT DISTINCT
  'SCHEMA1' AS SCHEMA_NAME
 ,TABLE_NAME
FROM SCHEMA1.COLS
WHERE COLUMN_NAME LIKE '%ID%'
UNION
SELECT DISTINCT
  'SCHEMA2' AS SCHEMA_NAME
 ,TABLE_NAME
FROM SCHEMA2.COLS
WHERE COLUMN_NAME LIKE '%ID%'

किसी भिन्न स्कीमा को देखने के लिए मैं इसका उपयोग कैसे करूँ? (मैं अपने मूल प्रश्न में उस रिक्वेस्ट का उल्लेख करना भूल गया)
डेविड वनिल

बस प्रत्येक तालिका नाम के सामने स्कीमा नाम प्रस्तुत करें ... यानी myschema.c1। स्पष्ट रूप से आपके पास अन्य
स्कीम

SELECT * FROM COLSमेरे स्कीमा से कुछ नहीं मिलता है। मेरे पास तालिकाओं पर केवल विशेषाधिकार हैं। क्या यह पर्याप्त नहीं होगा कि मुझे इसे COLS के माध्यम से देखने की अनुमति दी जाए?
डेविड वनिल

select * from schema1.colsमुझे एक table or view does not existत्रुटि देता है । कि विशेषाधिकार कैसे स्थापित किए जाते हैं?
डेविड वनिल

हाँ यह होगा। ऐसा लगता है कि टोनी एंड्रयू का जवाब शायद आपकी स्थिति के लिए बेहतर है। मैं "all_tab_columns" दृश्य के बारे में भूल गया था।
जोसफ्सटन्स

10

स्तंभ नाम खोजने के लिए नीचे दिए गए क्वेरी का उपयोग करें यदि आप स्तंभ नाम को ठीक से जानते हैं:

select owner,table_name from all_tab_columns where upper(column_name) =upper('keyword');

यदि आप नीचे दिए गए सटीक कॉलम उपयोग को नहीं जानते हैं, तो स्तंभ नाम खोजने के लिए:

select owner,table_name from all_tab_columns where upper(column_name) like upper('%keyword%');

0

यहाँ एक है जिसे हमने findcol.sql में सहेजा है ताकि हम इसे SQLPlus के भीतर से आसानी से चला सकें

set verify off
clear break
accept colnam prompt 'Enter Column Name (or part of): '
set wrap off
select distinct table_name, 
                column_name, 
                data_type || ' (' || 
                decode(data_type,'LONG',null,'LONG RAW',null,
                       'BLOB',null,'CLOB',null,'NUMBER',
                       decode(data_precision,null,to_char(data_length),
                              data_precision||','||data_scale
                             ), data_length
                      ) || ')' data_type
  from all_tab_columns
 where column_name like ('%' || upper('&colnam') || '%');
set verify on
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.