Oracle
 sql >> डेटाबेस >  >> RDS >> Oracle

किसी उपयोगकर्ता के लिए सभी Oracle डेटाबेस विशेषाधिकार कैसे दिखाएं

Oracle के भीतर सभी उपयोगकर्ता विशेषाधिकारों को पुनः प्राप्त करना एक साधारण कार्य से लेकर एक बुनियादी SQL क्वेरी का उपयोग करके एक उन्नत स्क्रिप्ट तक हो सकता है, जो मुख्य रूप से इस बात पर निर्भर करता है कि सर्वर के भीतर भूमिकाओं और विशेषाधिकारों को कैसे कॉन्फ़िगर किया गया है।

इस संक्षिप्त ट्यूटोरियल में, हम मूल SQL क्वेरी विधि के साथ-साथ उन्नत स्क्रिप्ट विधि दोनों को शामिल करेंगे ताकि आपके सेटअप की जटिलता की परवाह किए बिना आपको कोई समस्या न हो।

DBA/USER प्रिविलेज व्यू की क्वेरी करना

Oracle के लिए एक डेटाबेस व्यवस्थापक (DBA) केवल DBA_SYS_PRIVS में पंक्तियों को देखने के लिए एक क्वेरी निष्पादित कर सकता है , DBA_TAB_PRIVS , और DBA_ROLE_PRIVS system . से संबंधित उपयोगकर्ता विशेषाधिकारों के बारे में जानकारी प्राप्त करने के लिए , tables , और roles , क्रमशः।

उदाहरण के लिए, एक DBA जो सभी system . को देखना चाहता है सभी उपयोगकर्ताओं को दिए गए विशेषाधिकार निम्नलिखित प्रश्न जारी करेंगे:

SELECT
  *
FROM
  DBA_SYS_PRIVS;

DBA_SYS_PRIVS व्यू में डेटा के तीन कॉलम होते हैं:

  • GRANTEE वह नाम, भूमिका या उपयोगकर्ता है जिसे विशेषाधिकार सौंपा गया था।
  • PRIVILEGE वह विशेषाधिकार है जिसे सौंपा गया है।
  • ADMIN_OPTION इंगित करता है कि दिए गए विशेषाधिकार में ADMIN . भी शामिल है या नहीं विकल्प।

यह निर्धारित करने के लिए कि किन उपयोगकर्ताओं के पास प्रत्यक्ष है table . तक पहुंच प्रदान करें हम DBA_TAB_PRIVS . का उपयोग करेंगे देखें:

SELECT
  *
FROM
  DBA_TAB_PRIVS;

आप इस क्वेरी से लौटाए गए कॉलम के बारे में अधिक जानकारी के लिए आधिकारिक दस्तावेज़ देख सकते हैं, लेकिन महत्वपूर्ण कॉलम हैं:

  • GRANTEE दी गई पहुंच वाले उपयोगकर्ता का नाम है।
  • TABLE_NAME वस्तु का नाम है (तालिका, अनुक्रमणिका, अनुक्रम, आदि)।
  • PRIVILEGE GRANTEE . को दिया गया विशेषाधिकार है संबंधित वस्तु के लिए।

अंत में, DBA_ROLE_PRIVS की क्वेरी करना view में बहुत सारी जानकारी समान है लेकिन roles . पर लागू होती है इसके बजाय, जहां GRANTED_ROLE कॉलम विचाराधीन भूमिका को निर्दिष्ट करता है:

SELECT
  *
FROM
  DBA_ROLE_PRIVS;

वर्तमान उपयोगकर्ता के विशेषाधिकारों की क्वेरी करना

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

यह वैकल्पिक रूप से USER_ . को क्वेरी करके किया जाता है उपरोक्त के संस्करण DBA_ विचार। इस प्रकार, DBA_SYS_PRIVS को देखने के बजाय हम USER_SYS_PRIVS के बारे में पूछेंगे , इस तरह:

SELECT
  *
FROM
  USER_SYS_PRIVS;

चूंकि USER_ विशेषाधिकार दृश्य प्रभावी रूप से उनके DBA_ . के समान होते हैं समकक्ष, लेकिन केवल वर्तमान उपयोगकर्ता के लिए विशिष्ट, लौटाए गए डेटा के प्रकार और कॉलम नाम सभी DBA_ क्वेरी करते समय समान होते हैं कुल विचार।

सभी विशेषाधिकार खोजने के लिए उन्नत स्क्रिप्ट

जबकि उपरोक्त विधियाँ बुनियादी सिस्टम कॉन्फ़िगरेशन के लिए काम करेंगी, Oracle में चीजें गड़बड़ होने लगती हैं जब कई भूमिकाएँ मौजूद होती हैं जो बदले में अन्य भूमिकाओं को भूमिका विशेषाधिकार प्रदान करती हैं, और इसी तरह नीचे खरगोश के छेद में। चूंकि DBA_ और USER_ विशेषाधिकार दृश्य केवल प्रदर्शित करते हैं GRANTEES सीधे असाइन किए गए . के साथ एक्सेस, अक्सर विशेषाधिकार जो अन्य भूमिकाओं के माध्यम से विरासत में मिलते हैं, आसानी से नहीं दिखाए जाएंगे।

इसे हल करने के लिए, एक उन्नत स्क्रिप्ट का उपयोग करने की सलाह दी जाती है जैसे कि पीट फ़िनिगन का विश्वसनीय कार्य और उसका find_all_privs.sql लिखी हुई कहानी। आप डेविड आर्थर के संशोधित संस्करण को भी चुन सकते हैं, find_all_privs2.sql

किसी भी मामले में, इन स्क्रिप्ट का उद्देश्य आपको पुनरावर्ती . की अनुमति देना है किसी विशेष उपयोगकर्ता को दिए गए सभी विशेषाधिकारों का पता लगाएं। जब स्क्रिप्ट role का पता लगाती है उपयोगकर्ता के लिए, यह उस भूमिका को दी गई अन्य भूमिकाओं और विशेषाधिकारों के लिए पुनरावर्ती रूप से खोज करता है, इस प्रक्रिया को पूरी श्रृंखला में दोहराता है। स्क्रिप्ट के परिणाम स्क्रीन पर या वांछित फ़ाइल में आउटपुट हो सकते हैं।

इन लिपियों और उनके उपयोग के बारे में अधिक जानकारी petefinnigan.com पर देखी जा सकती है।


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. मैन्युअल रूप से संभव क्वेरी के भीतर पीएल/एसक्यूएल अपर्याप्त विशेषाधिकार

  2. Oracle में एक तिथि से वर्ष प्राप्त करने के लिए 2 कार्य

  3. Oracle डेटाबेस में PL/SQL पैकेज कैसे बनाएँ?

  4. स्टैंडबाय पर लॉगिंग करने में त्रुटि 1033 प्राप्त हुई

  5. Oracle में निर्देशिका कैसे बनाएं?