مرتضی دلیل
مرتضی دلیل
خواندن ۳ دقیقه·۵ سال پیش

بازگشت به ریشه و کار با Dapper

فرض من در این مقاله این است که :

  • برنامه نویس Asp.Net باشید و با Sql و Ado.net آشنا باشید.
  • با EntityFramework آشنا باشید.

قبل از اینکه مقاله را شروع کنم کد زیر را ببینید:

https://gist.github.com/130487000d7d60a2ea8d373230b9d0ec

حدس بزنید چه اتفاقی افتاده است؟ بر اساس کانکشنی که تعریف کردیم به کمک دستور SqlConnection، کانکشن را باز کرده و با متد QueryFirst یک دستور Select Top 1 را اجرا و خروجی را به شکل string در متغیر titleName ریختیم.

خیلی شبیه ADO.Net است ولی خروجیِ کوئری، تایپ دارد؛ برای ما برنامه نویس ها جذاب است و از این لحاظ شبیه EF عمل میکند.

دپر به عنوان یک ORM کوچک (Micro ORM) شناخته می‌شود. این کتابخانه‌ی بسیار پرکاربرد، حدود سال 2011 توسط تیم برنامه نویسی Stackoverflow منتشر شد. اما چرا دپر با وجود ORM های قدرتمندی مثل EntityFramework اینقدر پر طرفدار شده است؟ پروژه Stackoverflow در لایه دیتا از روش Linq2Sql استفاده می‌کرد اما به دلیل توسعه سریع پروژه Stackoverflow و ریکوئست ها و کوئری های زیاد مشکل پرفورمنسی برای پروژه بوجود آمد و مجبور شدند به Dapper مهاجرت کنند. این مهاجرت بیشتر در بخش کوئری ها انجام شد و Insert ها به همان روش قدیمی تا چند وقت قبل انجام می‌شد. این موضوع تا اکتبر 2018 ادامه یافت تا اینکه Nick Craver به عنوان معمار اصلی پروژه Stackoverflow اعلام کرد بطور کلی به EF Core مهاجرت خواهند کرد.

با این مقدمه، سوال مهمی که پیش می آید این است که چه موقع دپر انتخاب مناسبی خواهد بود؟

دپر کتابخانه فوق العاده سبکیست که شامل قابلیت های ابتدایی کار با دیتابیس است، یعنی از این لحاظ اصلا قابل مقایسه با EF یا Nhibernate نیست. نکته مثبت این ویژگی، در کمتر دستکاری شدن کوئری های شماست. شما به کمک دپر مستقیما کد T-SQL می‌نویسید و دپر فقط وظیفه مپ کردن مدل های شما را به عهده می‌گیرد. مپ کردن آیتم های جدول های دیتابیس به آبجکت های سی شارپ. همین.

در EntityFramework کنترل شما روی کوئری ها کامل نیست. یعنی با چند Join و Group توسط Linq یا Extension Method ها چیزی که پشت صحنه توسط EF به شکل کوئری T-SQL ساخته میشود گاهی عجیب و غریب و هزینه زا است. بدِ ماجرا اینجاست که اکثرا توسعه دهنده متوجه این فاجعه نمی‌شود و پرفورمنس برنامه پایین می‌آید.

در دپر شما دقیقا می‌دانید چه نوع کوئری اجرا می‌شود چون دقیقا همان کوئری SQL را می‌نویسید.

در کنار مزیت گفته شده، این موضوع را در نظر بگیرید که مهارت در کار با Linq و EntityFramework معمولا باعث کم کاری در کوئری نویسی T-SQL می‌شود و این موضوع نه تنها فایده ای ندارد بلکه از قدرت و مهارت شما در بخش SQL می‌کاهد. Dapper می‌تواند این خلاء را نیز پر کند.

سوال دیگر اینکه دپر به درد چه کسانی نمی‌خورد؟

گروه اول کسانی هستند که حوصله کوئری نوشتن با T-Sql را ندارند و غرق در Linq و امکانات EF هستند. برای این افراد دپر یک عذاب است.

گروه دوم کسانی که می‌خواهند پروژه ای که قبلا انجام داده اند را به دپر تبدیل کنند و پروژه سرشار از پیاده سازی و توسعه ی امکانات EF است و مثلا Tracking های EF همه جا ریشه دوانده باشد. به نظر برای این افراد مهاجرت به دپر چندان منطقی نیست.

نکته آخر اینکه معجزه دپر وقتی برای شما روشن می‌شود که مثل توسعه دهندگان Stackoverflow بخش حساس پروژه خود را که کوئری های پیچیده و بزرگ است به شکل دپری پیاده سازی کنید و از امکانات EF در بقیه جاهای پروژه استفاده کنید. این یعنی الزامی نیست که کل پروژه خود را از EF به Dapper منتقل کنید. Insert,Update,Delete عملیاتی هستند که چندان هزینه عجیبی ندارند و EF به سادگی از عهده آن بر می‌آید. می توانید پروژه خود را به شکل CQRS جلو ببرید و بخش های کامند را با EF و بخش های کوئری را با Dapper پیاده سازی کنید.

آموزش dapperمعرفی دپرasp net core
برنامه نویس و علاقمند به برنامه نویسی، سینما، فلسفه و هر چیزی که هیجان انگیز باشد. در ویرگول از روزمرگیهای مرتبط با علاقمندیهام خواهم نوشت. در توئیتر و جاهای دیگر @mortezadalil هستم.
شاید از این پست‌ها خوشتان بیاید