sql - Case statement in where clause not working -


मित्र ..

मैं संग्रहीत कार्यविधि का उपयोग कर रहा हूं जिसमें एक वैकल्पिक पैरामीटर @ बराबर और डिफ़ॉल्ट मान नल है यदि उपयोगकर्ता पैरामीटर एसक्यूएल क्वेरी को कुछ मान देता है तो उसे बदलना होगा। मैं कहाँ क्लॉज में केस का उपयोग करने की कोशिश कर रहा हूं लेकिन इसकी कुछ त्रुटि दिखाई दे रही है उचित सिंटैक्स या बेहतर तर्क के साथ मेरी सहायता करें

मेरी आवश्यकता तब होती है जब उपयोगकर्ता @ समान के लिए मूल्य नहीं देते हैं, तो फ़िरस्क्रीन साल & lt; @yr - अन्य
वित्तीय वर्ष और एलटी; = @ यार <प्री> बैंककोड का चयन करें, (एसएम (डेबिट) - एसओएम (क्रेडिट)) एटी से वी डब्ल्यु डेलीडेटा जहां पीएनजी = @ पैरिश नाम और फिस्कल साल & lt; (केस जब @ इक्वल आईएस नेल है, तो @ ईआरएसईई = '+ @ yr) और बैंककोड & lt; & gt; बैंक' बैंक 'द्वारा' कैश 'समूह

संशोधित प्रश्न < / P>

  बैंककोड का चयन करें, (एसएम (डेबिट) - एसओएम (क्रेडिट)) एटी से वी डब्ल्यु डेलीडेटा, जहां पीएनजी = @ पैरिश नाम और (जब मामला बराबर है तो अब फिसल ईयर और एलटी; @ एआर ईडीडी) और बैंककोड & lt; & gt; बैंकिंग के द्वारा 'कैश' समूह   

त्रुटि बयान संदेश 102, स्तर 15, राज्य 1, प्रक्रिया spDisplayBankConolidate, रेखा 14 '& lt;' के पास गलत वाक्यविन्यास

आपकी स्थिति में आपकी दो त्रुटियां हैं:

  • END की कमी है , और
  • आप case अभिव्यक्ति के अंदर एक अलग ऑपरेटर नहीं दे सकते।

    स्थिति इस तरह दिखनी चाहिए:

      जहां पन्नें = @ पैरिश नाम और ((असमान है नाल और वित्तीय वर्ष और लेफ्टिनेंट @ आईआर) या (समानांतर नहीं है और फसल वर्ष के लिए & lt; = @yr)) और बैंककोड & lt; & gt; 'कैश'   

    N या अभिव्यक्ति के दो हिस्सों में @equal IS NULL और @equal IS NOT NULL शर्तों को छोड़ दें। चूंकि दोनों पारस्परिक रूप से अनन्य हैं, इसलिए या के एक ही पक्ष का फैसला होगा कि क्वेरी परिणाम में कौन से पंक्तियां शामिल होंगी।

Comments

Popular posts from this blog

java - ImportError: No module named py4j.java_gateway -

python - Receiving "KeyError" after decoding json result from url -

.net - Creating a new Queue Manager and Queue in Websphere MQ (using C#) -