postgresql - Call plpgsql function in select's where clause -


मेरे पास एक plpgsql फ़ंक्शन fillwhere (parameter1 date) जो एक जटिल रिटर्न जहां एक पाठ के रूप में खंड , मान लीजिए कि यह एक कोड के रूप में clause2 = filter2 देता है, लेकिन यह वास्तव में अन्य खंडों का एक गुच्छा देता है।

मुझे इस फ़ंक्शन को एक चयन में कॉल करने की आवश्यकता है जहां खंड पूरक कि खंड, यह है कि मैंने अभी तक क्या किया है:

  SELECT value1 से तालिका 1 WHERE clause1 = filter1 और पूरक जगह (पैरामीटर 1);  

लेकिन यह त्रुटि देता है

का तर्क WHERE का प्रकार होना चाहिए प्रकार बूलियन, प्रकार टाइप नहीं

क्या है ऐसा करने का सही तरीका?

आप एक टेक्स्ट मूल्य कोड में, जो आमतौर पर SQL में संभव नहीं है आपको या तो सर्वर पर दो दौर यात्राएं करने की आवश्यकता है।

  1. प्राप्त करें WHERE खंड: SELECT पूरक जगह ('& lt; mydate & gt;')
  2. SELECT क्वेरी को कंसैट करें
  3. इस क्वेरी को निष्पादित करें: SELECT .. WHERE ...

या (अधिमानतः) गतिशील का उपयोग करें एसक्यूएल एक पीएल / पीजीएसयूएलएल फ़ंक्शन में है। एसओ पर बहुत से उदाहरण हैं।

आपने अपना वास्तविक कोड नहीं दिया ...

एसक्यूएल इंजेक्शन < / Strong> जब भी आप उपयोगकर्ता इनपुट को कोड में बदल देते हैं।


Comments

Popular posts from this blog

sqlite3 - UPDATE a table from the SELECT of another one -

c# - Showing a SelectedItem's Property -

javascript - Render HTML after each iteration in loop -