linq - Adding where and sum to lambda expression -


मेरे पास लिनक क्वेरी नीचे है:

  var qry = आउटपुट में db.Outputs आउटपुट पर शिफ्टहौर्स में शामिल हों। शिफ्टहॉरस आउटपुट पर। शिफ्टहौर शिफ्टहौर के बराबर हैं। शिफ्टआप डीबी में शिफ्टडाटा में शामिल हों। आउटपुट पर शिफ्टडेट्स। शिफ्टआइएड शिफ्टडाटा के बराबर है। शिफ्टआइड जहां शिफ्टडाटा। शिफ्टडेट == तारीख और amp; ShiftData.Line == लाइन नई प्रगतिडेटा () का चयन करें (CPM = ShiftData.CPM, लक्ष्य = ShiftData.Target, CurrentOutput = db.Outputs.Sum (x = & gt; x.Quantity), PercentOfTarget = (db.Outputs.Sum X = & gt; x.Quantity) / ShiftData.Target) * 100};   

यह लगभग मैं क्या चाहता हूं, लेकिन जैसा कि यह खड़ा है, वर्तमान आउटपुट लैम्ब्डा अभिव्यक्ति आउटपुट तालिका की संपूर्ण मात्रा कॉलम की राशि लौट रहा है क्योंकि मुझे कोई अनिश्चित नहीं है कि कैसे एक ' जहां 'खंड और साथ ही योग समारोह (और इसलिए PercentOfTarget भी गलत है)।

जहां खंड पहले की तरह ही होना चाहिए, जहां खंड (तिथि और पंक्ति विधि को पारित पैरामीटर हैं):

  जहां ShiftData.ShiftDate == तिथि और ; & amp; ShiftData.Line == रेखा   

क्या कोई भी मदद कर सकता है?

संपादित करें: वर्तमानऑप्टपुट का स्पष्टीकरण।

'आउटपुट' तालिका में दिए गए 'शिफ्टडाटा। शिफ्टडेट' और 'शिफ्टडाटा लाइन' संयोजन के लिए कई रिकॉर्ड हो सकते हैं, इसलिए मैं निर्दिष्ट 'शिफ्टडाटा' के लिए 'आउटपुट' टेबल 'मात्रा' कॉलम के मूल्यों की गणना करना चाहूंगा और 'रेखा'

संपादित करें: आगे स्पष्टीकरण

यह आउटपुट तालिका से कुछ नमूना डेटा है (आउटपुटआईड एक स्वत: वेतन वृद्धि पीके है):

यहां छवि विवरण दर्ज करें

  सार्वजनिक वर्ग के आउटपुट {{कुंजी ] सार्वजनिक इंक आउटपुट आईडी {प्राप्त; सेट; } सार्वजनिक पूर्णांक शिफ्टआईडी {प्राप्त करें; सेट; } सार्वजनिक int मात्रा {प्राप्त करें; सेट; } सार्वजनिक इंट शिफ्टहौर {get; सेट; } सार्वजनिक आभासी ShiftData ShiftData {get; सेट; }}   

यह शिफ्टडाटा तालिका से कुछ नमूना डेटा है (शिफ्टआईड एक ऑटो-इन्क्रिममेंट पीके है, प्रत्येक लाइन के लिए एक से अधिक रिकॉर्ड होंगे क्योंकि आगे लाइन नंबर जोड़े जाते हैं): < / P>

यहां छवि विवरण दर्ज करें

  सार्वजनिक वर्ग ShiftData { [कुंजी] सार्वजनिक एट सीआईआईआईआईडी {प्राप्त करें; सेट; } सार्वजनिक दिनांक समय ShiftDate {get; सेट; } सार्वजनिक स्ट्रिंग लाइन {get; सेट; } सार्वजनिक इंट सीपीएम {प्राप्त; सेट; } सार्वजनिक डबल लक्ष्य {get; सेट; }}   

तो उपरोक्त नमूना डेटा का उपयोग करके, मैं एक प्रगति डेटा ऑब्जेक्ट को आबाद करने की कोशिश कर रहा हूं:

  सार्वजनिक श्रेणी ProgressData {सार्वजनिक इंट CPM {get; सेट; } सार्वजनिक डबल लक्ष्य {get; सेट; } सार्वजनिक int चालूऑप्टपुट {get; सेट; } सार्वजनिक डबल प्रतिशत OfTarget {get; सेट; }}   

नमूना डेटा के आधार पर, मैं उम्मीद करता हूं कि मेरी प्रगतिडेटा ऑब्जेक्ट पंक्ति 1 के लिए 13/2/2014 को बनाई गई है, जैसे कि आबाद हो:

सीपीएम = 5, लक्ष्य = 200, वर्तमानऑप्टपुट = 120, प्रतिशत = लक्ष्य = 60

आप उस प्रयोजन के लिए करने की कोशिश कर सकते हैं: <प्री> var qry = db.ShiftDatas में से ShiftData से आउटपुट में शामिल हैं। ShiftData पर शॉर्टकट। शिफ़्टआइमेंट आउटपुट के बराबर है। शिफ्टग्यूड में ShiftGroup जहां ShiftData.ShiftDate == तिथि & amp; & amp; ShiftData.Line == लाइन नई प्रगतिडेटा () का चयन करें (सीपीएम = शिफ्टडाटा। सीपीएम, लक्ष्य = शिफ्टडाटा। लक्ष्य, वर्तमानऑपरपुट = शिफ्ट ग्रुप। सैम (एक्स = & gt; एक्स। क्वांटिटी), प्रतिफल = लक्ष्य = (ShiftGroup.Sum (x = & gt; X.Quantity) / ShiftData.Target) * 100};

एक और बात, मैं देख नहीं सकता कि आपको शिफ्टहौर के साथ जुड़ने की आवश्यकता क्यों है, क्योंकि इसमें से कोई भी चयन कथन में प्रयुक्त नहीं है।

Comments

Popular posts from this blog

c - Mpirun hangs when mpi send and recieve is put in a loop -

python - Apply coupon to a customer's subscription based on non-stripe related actions on the site -

java - Unable to get JDBC connection in Spring application to MySQL -