मुझे पंक्तियों से चयन करते समय त्रुटि मिल रही है। ASNumerable()। मैं निम्नलिखित कोड का उपयोग कर रहा हूँ ...लिंक और डीबीएनयूएल - त्रुटि प्राप्त करना
var rows = ds.Tables[0].AsEnumerable();
trafficData = rows.Select(row => new tdDataDC
{
CalculationCount = row.Field<Int64>("biCalculationCountSeqID")
, Zone = row.Field<Int16>("siFkZoneId")
, Miles = row.Field<decimal>("dcMiles")
, Plaza = row.Field<Int16>("siFkPlazaId")
, VehicleCount = row.Field<int>("iVehicleCount")
});
समय यह अच्छी तरह से काम करता है, लेकिन जब वहाँ डेटाबेस में NULLS मैं इस त्रुटि मिल रही हैं "टाइप करने के लिए 'System.Int16 DBNull.Value नहीं दिया जा सकता से अधिकांश 'कृपया एक शून्य प्रकार का उपयोग करें .. " मैं इसे कैसे ठीक कर सकता हूं? मैं नहीं चाहता कि मेरे डेटाकंट्रैक्ट्स में नलबल प्रकार हों, मैं एक टर्नरी या कुछ का उपयोग करना चाहता हूं, और यदि कोई मान नल है, तो बस इसका उपयोग करें। क्या यह संभव है?
किसी भी मदद के लिए धन्यवाद,
~ सी.के.
मैं मार्क का जवाब चाहते हैं, लेकिन इसे करने का एक और तरीका है पाने के लिए, आप मूल्य प्रकार बदलने के नल (कम होने के लिए कर सकता है? लंबा? आदि) और फिर coalesce, तो पंक्ति की तरह कुछ। फ़ील्ड ("foo") ?? 0 –
बीटीडब्ल्यू, 2 पंक्ति कॉल करने के बजाए, यदि टी हमेशा एक मान प्रकार है, तो आप पंक्ति कर सकते हैं। फ़ील्ड> (कॉलमनाम) ?? डिफ़ॉल्ट (टी) हालांकि मुझे संदेह है कि यदि आप संदर्भ प्रकारों का भी उपयोग करते हैं तो यह परेशानी के लायक है :) –