linq - Parse string as DateTimeOffset in Expression<Func<T, bool>> -


अरे, मैं एक अभिव्यक्ति & lt; Func & lt; T, bool & gt; & gt; बनाने की कोशिश कर रहा हूं जो कि एक स्ट्रिंग संपत्ति को कनफेट किया जाता है / एक डेटटाइम ऑफसेट में डाली जाती है, ताकि डेटटाइम ऑफसेट ऑपरेशन उस पर किया जा सके।

हम अपने डेटा प्रदाता के रूप में Linq2SQL का प्रयोग कर रहे हैं, जो स्ट्रिंग को डेटटाइमऑफसेट के समकक्ष समनुरूप रूपांतरित करने का समर्थन करता है। आदर्श रूप से मैं सीधे IQueryable डेटा स्रोत के भीतर अभिव्यक्ति का मूल्यांकन करना चाहता हूं, और एक IEnumerable के रूप में मेमोरी में नहीं।

मैं दूर करने की कोशिश की एक उदाहरण के लिए नीचे देखें:

  सार्वजनिक वर्ग MyClass {सार्वजनिक स्ट्रिंग मायवल्यू; } अभिव्यक्ति & lt; Func & lt; MyClass, bool & gt; & gt; फ़िल्टर = एमसी = & gt; दिनांकटाइमऑफ़सेट। पर्स (एमसीएम वेल्यू) & gt; नया दिनांक समयऑफसेट (2007,1,1);  

दुर्भाग्य से, फ़िल्टर की इस परिभाषा में स्मृति मूल्यांकन होता है।

<पी > चूंकि अंतर्निहित भौतिक तालिका स्तंभ nvarchar not datetime है, मुझे लगता है कि आप भाग्य से बाहर हैं LINQ2SQL प्रदाता जानता है कि यह nvarchar डेटा है, और इसलिए वह मूल एसक्यूएल अभिव्यक्तियां उत्पन्न नहीं करेगा जो इसके साथ datetime मान के रूप में काम करती हैं।

ईमानदार, मैं इसे हाथों से तैयार किए गए कूल्हे SqlCommand ऑब्जेक्ट के साथ करने का एक सुरक्षित तरीका भी नहीं देख सकता आपको वास्तव में मेमोरी में डेटा को स्ट्रिंग के रूप में पढ़ना चाहिए, फिर उसे DateTimeOffset में कनवर्ट करना चाहिए, फिर उसे मैन्युअल रूप से मेमोरी में फिल्टर करना चाहिए। यदि आप इस स्तंभ पर मूल एसक्यूएल फ़िल्टरिंग चाहते हैं, तो आपको तालिका स्कीमा को बदलना होगा।


Comments

Popular posts from this blog

MySql variables and php -

url rewriting - How to implement the returnurl like SO in PHP? -

Which Python client library should I use for CouchdB? -