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

क्या PostgreSQL फ़ंक्शंस के अंदर psql वैरिएबल के लिए कोई एस्केपिंग सिंटैक्स है?

पीएसक्यूएल SET डॉलर-उद्धृत स्ट्रिंग्स के अंदर चर को प्रक्षेपित नहीं किया जाता है। मैं यह निश्चित रूप से नहीं जानता, लेकिन मुझे लगता है कि SET चालू करने के लिए कोई बच निकलने या अन्य चालबाजी नहीं है वहाँ में परिवर्तनशील प्रक्षेप।

कोई सोच सकता है कि आप एक गैर-उद्धृत :user . को काट सकते हैं वांछित प्रभाव प्राप्त करने के लिए पीएल/पीजीएसक्यूएल के दो डॉलर-उद्धृत हिस्सों के बीच। लेकिन यह काम नहीं कर रहा है ... मुझे लगता है कि सिंटैक्स के लिए एक स्ट्रिंग की आवश्यकता होती है, न कि स्ट्रिंग्स को जोड़ने वाली अभिव्यक्ति। उस पर गलती हो सकती है।

वैसे भी, इससे कोई फर्क नहीं पड़ता। एक और दृष्टिकोण है (जैसा कि पास्को ने नोट किया है):पीएल/पीजीएसक्यूएल तर्क स्वीकार करने के लिए संग्रहीत प्रक्रिया लिखें। यह ऐसा दिखाई देगा।

CREATE OR REPLACE FUNCTION foo("user" TEXT) RETURNS void AS
$$
BEGIN
        EXECUTE 'GRANT SELECT ON my_table TO GROUP ' || quote_ident(user);
END;    
$$ LANGUAGE plpgsql;

इस फ़ंक्शन पर नोट्स:

  1. EXECUTE एक उपयुक्त GRANT उत्पन्न करता है हमारे प्रक्रिया तर्क पर प्रत्येक आमंत्रण पर। "डायनामिक कमांड निष्पादित करना " EXECUTE के बारे में बताता है विस्तार से।
  2. प्रक्रिया तर्क की घोषणा user दोहरा उद्धृत किया जाना चाहिए। दोहरे उद्धरण इसे एक पहचानकर्ता के रूप में व्याख्या करने के लिए मजबूर करते हैं।

एक बार जब आप फ़ंक्शन को इस तरह परिभाषित कर लेते हैं, तो आप इसे इंटरपोलेटेड पीएसक्यूएल चर का उपयोग करके कॉल कर सकते हैं। यहाँ एक रूपरेखा है।

  1. चलाएँ psql --variable user="'whoever'" --file=myscript.sql . उपयोगकर्ता नाम के आसपास एकल उद्धरण आवश्यक हैं!
  2. myscript.sql में, ऊपर की तरह फ़ंक्शन को परिभाषित करें।
  3. myscript.sql में, select foo(:user); . डालें . यह वह जगह है जहां हम उन एकल उद्धरणों पर भरोसा करते हैं जिन्हें हम user . के मूल्य में रखते हैं .

हालांकि यह काम करने लगता है, यह मुझे स्क्वीयरली के रूप में प्रभावित करता है। मैंने सोचा SET चर रनटाइम कॉन्फ़िगरेशन के लिए अभिप्रेत थे। SET . में डेटा ले जाना अजीब लगता है।

संपादित करें :यहाँ नहीं का एक ठोस कारण है SET का उपयोग करें चर। मैनपेज से:"ये असाइनमेंट स्टार्टअप के बहुत शुरुआती चरण के दौरान किए जाते हैं, इसलिए आंतरिक उद्देश्यों के लिए आरक्षित चर बाद में अधिलेखित हो सकते हैं।" यदि Postgres ने user . नामक चर का उपयोग करने का निर्णय लिया है (या जो भी आप चुनते हैं), यह आपके स्क्रिप्ट तर्क को उस चीज़ से अधिलेखित कर सकता है जिसका आपने कभी इरादा नहीं किया था। वास्तव में, psql पहले से ही USER लेता है अपने लिए -- यह केवल इसलिए काम करता है क्योंकि SET केस सेंसिटिव है। इसने शुरू से ही चीजों को लगभग तोड़ दिया!



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Psycopg2 के साथ सर्वर साइड कर्सर का उपयोग कैसे करें

  2. विशेषाधिकारों के साथ एक भूमिका छोड़ें

  3. डिबग कैसे करें:आंतरिक त्रुटि वर्तमान लेनदेन निरस्त कर दिया गया है, लेनदेन ब्लॉक के अंत तक आदेशों को नजरअंदाज कर दिया गया है

  4. PostgreSQL में ऑपरेशन क्वेरी के इस घंटे को पूरा करें

  5. PostgreSQL के लिए सुरक्षा ऑडिट को स्वचालित करना