در مطلب قبلی ، مدل EAV را معرفی کردیم و گفتیم که این نوع پیادهسازی در واقع یک SQL Smell است؛ زیرا کوئری نویسی را سخت میکند و همچنین به دلیل عدم امکان تعریف constraints، کنترلی بر روی صحت دیتاهای وارده شد نخواهیم داشت. در نهایت با برنامهای روبرو خواهیم شد که درک صحیحی از ماهیت دیتا ندارد. اما اگر در شرایطی مجبور به استفادهی از این مدل هستید، بهتر است از فرمت JSON برای ذخیرهسازی دیتای داینامیک استفاده کنید. بیشتر دیتابیسهای رابطهایی ...
جدول اعضای این مجموعه، خود ارجاع دهنده طراحی شدهاست: namespace EFCorePgExercises.Entities
{
public class Member
{
// ...
public virtual ICollection<Member> Children { get; set; }
public virtual Member Recommender { set; get; }
public int? RecommendedBy { set; get; }
// ...
}
}
در اینجا RecommendedBy، یک کلید خارجی نال پذیر است که به Id همین ...
یکی از چالشهای دیتابیسهای رابطهایی، ذخیرهسازی دادههایی با ساختار داینامیک است. در حالت عادی، یک جدول مجموعهایی از موجودیتها است. هر موجودیت نیز شامل یکسری ویژگیهای (Attributes) مشخص میباشد. اما شرایطی را در نظر بگیرید که تعداد این ویژگیها به صورت مشخص و ثابتی نباشد؛ یعنی برای هر موجودیت، ویژگیهای متفاوتی داشته باشیم. یک روش پیادهسازی اینچنین سناریوهایی، استفاده از مدلی با نام Entity Attribute Value است. در این روش ستونهای داین ...
هدف از این سری مثالها، آشنایی با متدها و توابعی است که در حین کار با خواص رشتهای در LINQ to Entities، مجاز به استفادهی از آنها هستیم و همچنین اگر تابعی در EF-Core هنوز تعریف نشده بود، راه حل چیست. مثال 1: نام تمام کاربران را با قالب 'Surname, Firstname' نمایش دهید. var members = context.Members
.Select(member => new { Name = member.Surname + ", " + member.FirstName })
...
در کوئریهای قسمتهای قبل نیز تعدادی از آنها بر اساس فیلتر اطلاعات یک روز خاص، گروه بندی اطلاعات بر اساس ماهها و یا گروه بندی اطلاعات بر اساس روزها، بدون درنظر گرفتن قسمت زمان تاریخ، تهیه شدند. در این قسمت مثالهای دیگری را از این دست بررسی میکنیم. مثال 1: تعداد روزهای هر ماه سال 2012 را محاسبه کنید.
ستونهای این گزارش باید از سه مقدار عددی Year, Month, DaysInMonth تشکیل شوند. var items = context.Bookings
...
کوئریهای تجمعی این قسمت، کمی پیچیدهتر هستند و برای حل آنها باید از window functions استفاده کرد و چون این مفهوم توسط EF-Core پشتیبانی نمیشود (منظور توسط LINQ to Entities آن است و نه SQL نویسی مستقیم)، در بعضی از موارد مجبور خواهیم شد اطلاعات مورد نیاز گزارش را از بانک اطلاعاتی دریافت کرده و سپس در سمت کلاینت توسط LINQ to Objects شکل دهی کنیم.
مثال 12: محاسبه کنید در سال 2012 و به ازای هر ماه مجزای آن، چه تعداد slots رزرو ...
در مطلب قبل نحوهی ایجاد روابط Polymorphic را بررسی کردیم و همچنین چندین راهحل جایگزین را نیز ارائه دادیم. همانطور که عنوان شد این نوع روابط اساساً از لحاظ طراحی دیتابیس اصولی نیستند و تا حد امکان نباید استفاده شوند. این نوع روابط بیشتر ORM friendly هستند و اکثر فریمورکهای غیرداتنتی به عنوان یک گزینهی توکار، امکان ایجاد این روابط را فراهم میکنند. به عنوان مثال در Laravel Eloquent ORM به صورت توکار از این قابلیت پشتیبانی میشود: ...
امکان انجام محاسبات تجمعی، یکی از مواردی است که قدرت بانکهای اطلاعاتی رابطهای را نمایش میدهد. توسط این نوع کوئریها از محدودهی CRUD (ثبت/ویرایش/به روز رسانی) خارج شده و وارد دنیای تصمیمگیریها میشویم. تعداد مثالهای اعمال تجمعی این سری قابل توجهاست. به همین جهت در دو قسمت ارائه میشوند. مثال 1: چه تعداد امکانات، توسط این مجموعه ارائه میشود؟ var count = context.Facilities.Count();
برای شمارش سادهی تعداد ردیفهای ...
سناریویی را در نظر بگیرید که برای هر کدام از مدلهای Article, Video, Event میخواهیم قابلیت کامنتگذاری جداگانهای را داشته باشیم. چندین روش برای پیادهسازی این سناریو وجود دارد که در ادامه به آنها خواهیم پرداخت. Polymorphic association در این روش بجای تعریف چند کلید خارجی، تنها یک فیلد جنریک را تعریف خواهیم کرد که میتواند همزمان یک ارجاع را به مدلهای مطرح شده داشته باشد. برای تعیین نوع کلید هم نیاز به یک فیلد دیگر جهت ...
نوع دیگری از کوئریهای پرکاربرد، کوئریهای مرتبط با ثبت، حذف و ویرایش اطلاعات هستند که در این قسمت آنها را بررسی میکنیم. البته این مثالها از یکسری مثال کوئریهای مرتبط با PostgreSQL ، به EF-Core تبدیل و ترجمه شدهاند. به همین جهت تطابق یک به یکی در اینجا وجود نداشته و روش شیءگرایی که ORMها برای کار با دادهها بکار میگیرند، الزاما کوئریهای یکسانی را تولید نمیکنند؛ اما نتیجهی نهایی آنها یکی است. مثال 1: افزودن ردیفی به یک جدول ...