sql - Dapper: Procedure or function has too many arguments specified -


एक संग्रहीत कार्यविधि को कॉल करने के लिए डैपर का प्रयोग करते समय, मुझे निम्न त्रुटि प्राप्त हो रही है:

   

मैं क्वेरी को सरल पैरामीटर की सूची जोड़ने के लिए DynamicParameters का उपयोग कर रहा हूं।

पैरामीटर कोड इस प्रकार दिखता है:

  var पैरामीटर = नया डायनेमिक पारामेटर्स (); मापदंडों। जोड़ें (पी। नाम, पी। वेल, दिशा: पी.मोड);  

क्वेरी कोड इस प्रकार दिखता है:

  var परिणाम = _connection.Query & lt; T & gt; (string.Format ("{0}। {1} ", Request.SchemaName, request.StoredProcedureName), मापदंडों, कमांड टाइप करें: कमांडटाइप। स्टोटेड प्रोक्रिडर, ट्रांजैक्शन: _ ट्रांज़ैक्शन);  

प्रोफाइलर में निष्पादन एसक्यूएल निम्न के रूप में दिखाता है:

  exec dbo.storedProcedureName @ पैरामीटर नाम 1 = N'ParameterName ', @ पैरामीटर नाम 2 = N'ParameterName' , @ RemoveUnused = 1  

@ पैरामीटर नाम 1 बिल्कुल नहीं है कि पैरामीटर कैसे कहा जाता है। दरअसल, नामों के रूप में नामों के रूप में पारित किया जा रहा है (N'ParameterName ')। @RemoveUnused पैरामीटर पूरी तरह से मेरे लिए यादृच्छिक लगता है, क्योंकि यह कॉलिंग कोड में बिल्कुल भी नहीं होता है।

इस के लिए पूर्ण कोड यहां पाया जा सकता है: 61 और 228 लाइन पर।

< P> संपादित करें: मैंने पाया है कि इस मुद्दे को दो बार दो बार, अलग-अलग परिणाम सेट के साथ कॉल करने के कारण होता है। इसलिए पहली बार मैं इसे क्वेरी के साथ बुला रहा हूं, क्वेरी के साथ दूसरी बार। इस परिदृश्य में डापर को परेशानी क्यों हो रही है, यह अभी भी एक रहस्य है।

मैं इसे पुन: उत्पन्न नहीं कर सकता:

<पूर्व> सार्वजनिक शून्य SO25069578_DynamicParams_Procs () {var पैरामीटर = नया DynamicParameters (); Parameters.Add ("foo", "bar"); Try {connection.Execute ("drop proc SO25069578"); } पकड़ {} connection.Execute ("proc SO25069578 @ फु न्यूवर्चार (अधिकतम) के रूप में चुनें [foo] के रूप में [एक्स]"); Var tran = connection.BeginTransaction (); // gist प्रयुक्त लेनदेन; हालांकि वही पंक्ति = कनेक्शन। सीएक्स & lt; HazX & gt; ("SO25069578", मापदंडों, कमांड टाइप: कमांडटाइप। स्टोटेड प्रोक्रिडर, लेनदेन: ट्रॅन)। सिंगल (); tran.Rollback (); row.X.IsEqualTo ( "बार"); } सार्वजनिक वर्ग HazX {सार्वजनिक स्ट्रिंग X {get; सेट; }}

ठीक काम करता है है एक RemoveUnused पर संपत्ति DynamicParameters , बिट: गतिशील मापदंडों का उपयोग करते समय, जो नहीं जोड़ा जाना चाहिए । मैंने टेम्पलेट आधारित कंस्ट्रक्टर का उपयोग करने की कोशिश की है:

  पैरामीटर = नया डायनेमिक पैरामीटर (मापदंड);  

लेकिन फिर से: यह ठीक काम करता है क्या यह संभव है कि आप डापर का एक वाकई, वास्तव में पुरानी संस्करण का उपयोग कर रहे हैं? आप किस संस्करण का उपयोग कर रहे हैं?


Comments

Popular posts from this blog

Python Equivalent for matlab cart2pol and pol2cart -

sip - Call SipJs to Asterisk 12 -

java - Joda Time Interval Not returning what I expect -