postgresql - Call plpgsql function in select's where clause -
मेरे पास एक plpgsql फ़ंक्शन fillwhere (parameter1 date)
जो एक जटिल रिटर्न जहां एक पाठ के रूप में खंड , मान लीजिए कि यह एक कोड के रूप में clause2 = filter2
देता है, लेकिन यह वास्तव में अन्य खंडों का एक गुच्छा देता है।
मुझे इस फ़ंक्शन को एक चयन में कॉल करने की आवश्यकता है जहां खंड पूरक कि खंड, यह है कि मैंने अभी तक क्या किया है:
SELECT value1 से तालिका 1 WHERE clause1 = filter1 और पूरक जगह (पैरामीटर 1);
लेकिन यह त्रुटि देता है
का तर्क WHERE का प्रकार होना चाहिए प्रकार बूलियन, प्रकार टाइप नहीं
क्या है ऐसा करने का सही तरीका?
आप एक टेक्स्ट मूल्य कोड में, जो आमतौर पर SQL में संभव नहीं है आपको या तो सर्वर पर दो दौर यात्राएं करने की आवश्यकता है।
- प्राप्त करें
WHERE
खंड:SELECT पूरक जगह ('& lt; mydate & gt;')
। -
SELECT
क्वेरी को कंसैट करें - इस क्वेरी को निष्पादित करें:
SELECT .. WHERE ...
।
या (अधिमानतः) गतिशील का उपयोग करें एसक्यूएल एक पीएल / पीजीएसयूएलएल फ़ंक्शन में है। एसओ पर बहुत से उदाहरण हैं।
आपने अपना वास्तविक कोड नहीं दिया ...
एसक्यूएल इंजेक्शन < / Strong> जब भी आप उपयोगकर्ता इनपुट को कोड में बदल देते हैं।
Comments
Post a Comment