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

क्या अपडेट/डिलीट को अक्षम करने का कोई तरीका है लेकिन फिर भी ट्रिगर्स को उन्हें निष्पादित करने की अनुमति है?

हाँ, यह संभव है।

ट्रिगर्स को ट्रिगर फ़ंक्शन के विशेषाधिकारों के साथ चलाया जाता है, जो डिफ़ॉल्ट रूप से SECURITY INVOKER पर निर्भर करता है। जिसका अर्थ है, ट्रिगर फ़ंक्शन को current_user . के विशेषाधिकारों के साथ प्रभावी ढंग से निष्पादित किया जाता है , आपके मामले में पंक्तियों को सम्मिलित करने वाला।

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

हालांकि , आप SECURITY DEFINER . का उपयोग कर सकते हैं इस फ़ंक्शन को OWNER . के विशेषाधिकारों के साथ चलाने के लिए ट्रिगर फ़ंक्शन के लिए समारोह का।

यदि आपके पास एक सुपर उपयोक्ता स्वयं है ट्रिगर फ़ंक्शन, यह सब कुछ कर सकता है - जो एक संभावित सुरक्षा खतरा होगा। SECURITY DEFINER Writing लिखने के बारे में मैनुअल में दिए गए निर्देशों पर विचार करें सुरक्षित रूप से कार्य करता है।

लेकिन केवल आवश्यक विशेषाधिकारों के साथ एक सामान्य भूमिका निभाना समझदारी है OWNER ट्रिगर फ़ंक्शन का। आप लॉगिन के बिना भी "डेमन" भूमिका बना सकते हैं, इस तरह के संचालन के लिए विशेषाधिकार बंडल के रूप में कार्य कर सकते हैं। फिर आप इस डेमॉन भूमिका के लिए केवल आवश्यक विशेषाधिकार (स्कीमा, टेबल, अनुक्रम ...) प्रदान करेंगे। अधिक परिष्कृत डिजाइनों के लिए आपको विशेषाधिकारों को "समूह भूमिकाओं" (फिर से, कोई लॉगिन नहीं) में बंडल करना चाहिए और इन समूह भूमिकाओं को उन भूमिकाओं के लिए प्रदान करना चाहिए जिन्हें इसकी आवश्यकता है (इस उदाहरण में डेमन भूमिका के लिए), प्रभावी रूप से उन्हें "समूह का सदस्य" बनाना। मैं यह बहुत करता हूं।

फ़ंक्शन पर विशेषाधिकारों के संबंध में dba.SE पर इस संबंधित उत्तर पर विचार करें:

  • PostgreSQL 8.4 में ट्रिगर फ़ंक्शन को निष्पादित करने के लिए आवश्यक विशेषाधिकार क्या हैं?



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Postgresql में क्षैतिज शार्प का एक अच्छा तरीका क्या है?

  2. डेटटाइम ऑब्जेक्ट पर अलग-अलग टाइमज़ोन_टाइप्स

  3. PostgreSQL तार्किक प्रतिकृति का अनुकूलन कैसे करें

  4. PHP और पोस्टग्रेस:​​त्रुटियों को पकड़ना?

  5. क्या डेटाबेस के भीतर सरणियों का उपयोग करना खराब डिज़ाइन है?