نحوهی صحیح فراخوانی SQL Aggregate Functions حین استفاده از LINQ
چهارشنبه 26 تیر 1392نحوهی صحیح فراخوانی SQL Aggregate Functions حین استفاده از LINQ <br/> SQL Aggregate Functions که مد نظر شما هستند مانند Min ، Max ، Sum و امثال آن. بحث LINQ هم زمانیکه از الگوی Repository استفاده شود مستقل از نوع ORM مورد نظر خواهد شد؛
SQL Aggregate Functions که مد نظر شما هستند مانند Min ، Max ، Sum و امثال آن. بحث LINQ هم زمانیکه از الگوی Repository
استفاده شود مستقل از نوع ORM مورد نظر خواهد شد؛ بنابراین در اینجا مقصود
از LINQ میتواند LINQ to SQL ، LINQ to Entities ، LINQ to NHibernate و
کلا هر نوع ORM دیگری با پشتیبانی از LINQ باشد.
صورت مساله هم این است: آیا نوشتن عبارت LINQ ایی به شکل زیر صحیح است؟
پاسخ: خیر!
توضیحات:
عبارت LINQ فوق در نهایت به شکل زیر ترجمه خواهد شد:
و اتفاقا در این سیستم پس از تاریخ 2010/10/13 هیچ تراکنشی ثبت نشده است؛ بنابراین خروجی این کوئری null خواهد بود و نه صفر. همینجا است که یکی از استثناهای زیر صادر شده و ادامهی برنامه با مشکل مواجه خواهد شد:
مشکل هم از اینجا ناشی میشود که متغییری از نوع deciaml یا int و امثال آن، مقدار دریافتی نال را نمیپذیرند. برای رفع این مشکل باید عبارت LINQ فوق به صورت زیر بازنویسی شود (و اهمیتی هم ندارد که Sum است یا Max یا Avg و غیره؛ در مورد بکارگیری تمام SQL Aggregate Functions در یک عبارت LINQ ، این مورد باید لحاظ گردد):
دقیقا به همین علت است که در دات نت، nullable types تعریف شدهاند. امکان
ذخیره سازی null در یک متغیر برای مثال از نوع decimal وجود ندارد اما نوع
decimal? (و یا Nullable<decimal> به بیانی دیگر) این قابلیت را
دارد.
شاید بگوئید که در اینجا با تغییر تعریف متغیر به decimal? amount مشکل حل میشود، اما خیر. تعریف extension method مربوط به sum به صورت زیر است:
در این تعریف به TResult دقت نمائید؛ هم بیانگر نوع خروجی نهایی متد و هم
مشخص سازندهی نوع پارامتری است که خروجی Lambda Expression را تشکیل
میدهد. به این معنا که سی شارپ، TResult را از lambda expression دریافت
کرده و خروجی Sum را بر همان مبنا و نوع تشکیل میدهد. بنابراین برای
دریافت خروجی nullable باید TResult ایی nullable را همانند مثال فوق ایجاد
کنیم.
خلاصه بحث:
اگر در کدهای LINQ خود که با بانک اطلاعاتی سر
و کار دارند از معادلهای SQL Aggregate Functions استفاده کردهاید،
آنها را یافته و نکتهی nullable TResult فوق را به آنها اعمال کنید؛
در غیر اینصورت منتظر باشید تا روزی برنامه شما به سادگی کرش کند.
- SQL Server
- 3k بازدید
- 2 تشکر