fekre-bekr,learning,source,سورس,سورس رایگان,آموزش,اخبار,فناوری اطلاعات,mvc,.net,ساری,آموزشگاه,asp.net,c#.net,programing,c++,vb,آموزش برنامه نویسی,دانلود

اشتراک در سایت


مطالب تصادفی
اخبار و مقالات در فکر بکر آموزش ایجاد برنامه نصب (setup) قسمت سوم

در مراحل قبلی نحوه ایجاد فایل configuration و فایل نصب sql server و همچنین ایجاد setup برای نرم افزاری که باید در سیستم مشتری نصب ...


اخبار و مقالات در فکر بکر آموزش چگونگی نمایش ویو در پنجره مودال بوت استرپ در Asp.net MVC

در این مقاله به نمایش ویو در پنجره های Bootstrap Modal می پردازیم. لطفا به ادامه مطلب توجه نمایید. ...


اخبار و مقالات در فکر بکر سورس کامل web api در Asp.net MVC

در این سورس کدهای insert - delete - select all - select where و update قرار داده شد و شما میتوانید جهت دانلود سورس به ادامه مطلب ...


اخبار و مقالات در فکر بکر سورس بسیار زیبا به زبان c#

با سلام خدمت کاربران فکر بکر - سورس بسیار زیبایی را در این ساعت از فکر بکر بصورت رایگان برای شما جهت دانلود قرار دادم لطفا به اام ...


اخبار و مقالات در فکر بکر آموزش ایجاد آدرسهای کاربرپسند(user friendly URLs) در Asp.net MVC

با سلام – در این مقاله به آموزش ایجاد آدرسهای کاربر پسند در برنامه های Asp.net خواهم پرداخت User friendly بودن URLs فقط برای کا ...


اخبار و مقالات در فکر بکر آموزش نحوه ایجاد Extention method در C#

در این بخش با ارائه مثال عملی تبدیل تاریخ میلادی به شمسی به آموزش Extention method می پردازیم. ...


اخبار و مقالات در فکر بکر پیاده سازی سیستم احراز هویت کاربران در Asp.net MVC (بخش سوم)

با سلام خدمت کاربران عزیز فکر بکر، در ادامه اموزش پیاده سازی سیستم احراز هویت کاربران ابتدا به پیاده سازی سیستم ثبت نام کاربران ...


اخبار و مقالات در فکر بکر آموزش تحت شبکه کردن برنامه های مبتنی بر c# در sql server

در این آموزش به چگونگی استفاده از یک برنامه ویندوزی بصورت تحت شبکه توسط چندین سیستم خواهیم پرداخت. معمولا هر برنامه کاربردی دارا ...


اخبار و مقالات در فکر بکر آموزش نمایش تصویر loading در سمت client جهت بارگزاری صفحات با حجم زیاد از سرور در asp.net mvc

وبسایتهایی زیادی به این موضوع که با هر بار کلیک کاربر بر روی چیزی بدلیل سنگین بودن فایهای ارسالی از سرور و یا پردازش آن تصویر loa ...


اخبار و مقالات در فکر بکر آموزش عملیات CRUD با استفاده از Ragor Pages در Asp.net Core2.0

در این مقاله به آموزش عملیات CRUD که همان چهار عملیات اصلی (درج – حذف – بروزرسانی و انتخاب رکوردها ) می باشد را در محیط Asp.net c ...


اخبار و مقالات در فکر بکر آموزش استفاده از تابع Contains در عبارات lambda برای انواع مدلها

تابع Contains برای بررسی یک مقدار در یک مجموعه مورد استفاده قرار میگیرد اما نحوه استفاده این تابع برای مدلها نسبت به انواع اولیه ...


اخبار و مقالات در فکر بکر استفاده از AutoMapper در C #

با سلام – در این مقاله قصد دارم کلاس کاربردی AutoMapper را به شما کاربران فکر بکر معرفی کنم. ...


اخبار و مقالات در فکر بکر سورس بازی Minesweeper به زبان سی شارپ

در این ساعت از فکر بکر بازی زیبای Minesweeper که از بازیهای پرطرفدار در سیستم عامل ویندوز هست را میتوانید از فکر بکر دانلود نمایی ...


اخبار و مقالات در فکر بکر آموزش دستورات کاربردی در SQL

با سلام خدمت کاربران فکر بکر - جهت دانلود این آموزش به ادامه مطالب مراجعه نمایید ...


پیوندها
5 (1)

Repository یک design pattern می باشد که بعنوان یک واسط جهت کار با داده ها ودرون لایه Data Access Layer .که باعث میشوند منطق مورد نیاز برای ذخیره یا یازیابی داده ها پنهان شوند.
گروه : Asp.net Core
تاریخ انتشار: 1399/08/13

فکر بکر

Repository  یک  design pattern می باشد که بعنوان یک واسط جهت کار با داده ها  ودرون لایه Data Access Layer  .که باعث میشوند منطق مورد نیاز برای ذخیره یا یازیابی داده ها پنهان شوند.بتابراین برنامه ما از orm استفاده شده هیچگونه اطلاعاتی ندارد چرا که این موارد در لایه Repository انجام میگیرد.

یکی از مزایای مهم استفاده از Repository Pattern می تواند شامل کاهش در حجم کدنویسی باشد . چرا که ممکن است فرامین اسکیوال مشابهی در بخشهای مختلف برنامه اجرا گردد لذا با استفاده از الگوی Repository Pattern این مشکل حل خواهد شد.

در این آموزش پیاده سازی Repository Pattern بصورت  Generic Class خواهیم پرداخت. لذا برای شروع یک اینترفیس بنام IRepository بصورت زیر ایجاد میکنیم.

public interface IRepository<T> where T:class

    {

        T Get(int id);

        IEnumerable<T> GetAll(

            Expression<Func<T,bool>> filter=null,

            Func<IQueryable<T>,IOrderedQueryable<T>> orderby=null,

            string includeProperties=null

 

            );

        T GetFirstOrDefault(

             Expression<Func<T, bool>> filter = null,

              string includeProperties = null

             );

        void Add(T entity);

        void Remove(int id);

        void Remove(T entity);

    }

 سپس کلاس دیگری بنام Repository جهت پیاده سازی اینترفیس فوق بصورت زیر ایجاد میکنیم

  public class Repository<T> : IRepository<T> where T : class

    {

        protected readonly DbContext Context;

        private DbSet<T> dbSet;

        public Repository(DbContext context)

        {

            Context = context;

            this.dbSet = Context.Set<T>();

        }

        public void Add(T entity)

        {

            dbSet.Add(entity);

        }

 

        public T Get(int id)

        {

            return dbSet.Find(id);

        }

 

        public IEnumerable<T> GetAll(Expression<Func<T, bool>> filter = null, Func<IQueryable<T>, IOrderedQueryable<T>> orderby = null, string includeProperties = null)

        {

            IQueryable<T> query = dbSet;

            if (filter != null)

            {

                query = query.Where(filter);

            }

            //will br camma seperated

            if (includeProperties != null)

            {

              

                foreach (var includeProperty in includeProperties.Split(new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries))

                {

                 

                        query = query.Include(includeProperty);

                }

            }

            if (orderby != null)

            {

                return orderby(query).ToList();

            }

            return query.ToList();

        }

 

        public T GetFirstOrDefault(Expression<Func<T, bool>> filter = null, string includeProperties = null)

        {

            IQueryable<T> query = dbSet;

            if (filter != null)

            {

                query = query.Where(filter);

            }

            //will br camma seperated

            if (includeProperties != null)

            {

                foreach (var includeProperty in includeProperties.Split(new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries))

                {

                    query = query.Include(includeProperty);

                }

            }

            return query.FirstOrDefault();

        }

 

        public void Remove(int id)

        {

            T entityToRemove = dbSet.Find(id);

            Remove(entityToRemove);

        }

 

        public void Remove(T entity)

        {

            dbSet.Remove(entity);

        }

    }

در کلاس فوق ازتابع Set شیئ Context جهت نمونه سازی شیئ dbSet  استفاده کردیم.

در آموزشهای  بعدی به مبحث UnitOfWork و پیاده سازی عملی جهت استفاده در برنامه ها خواهیم پرداخت

 

پارسا محمودی
|
1399/08/13

خیلی خوب بود ممنون ✌
محمد مهدوی
|
1399/08/19

خواهش میکنم آقا پارسا

Nh9O67

آموزش پیاده سازی UnitOfWork در Asp.net Core قسمت اول -------- پیاده سازی Repository Pattern بصورت Generic Class -------- وارد کردن فقط حروف فارسی و جلوگیری از ورود حروف فارسی در تکست باکس با استفاده از JQuery -------- سورس استفاده از کامپوننت Roxy File manager در Asp.net core -------- آموزش ساخت صفحه Page Not Found (404) در Aspnet core -------- آموزش ایجاد Tag Helper سفارشی در Asp.net core -------- آموزش نحوه ایجاد Model برای دیتابیس موجود در Entity Framework Core -------- آموزش نحوه Upload و Download در Asp.net core 2 -------- آموزش dependency injection در Asp.net core 2 -------- آموزش تحت شبکه کردن برنامه های مبتنی بر c# در sql server -------- آموزش استفاده از Bundler & Minifier در Asp.Net Core -------- مروری بر Identity در Asp.net core2.1 (بخش دوم) -------- مروری بر Identity در Asp.net core2.1 (بخش اول) -------- آموزش مبحث Single Responsibility Principle (SRP) از بخش اصول طراحی شی گرا (SOLID) -------- آموزش publish کردن برنامه های Asp.net core بر روی سرور iis -------- پیاده سازی مسیریابی با استفاده از الگوریتم پیمایش اول سطح یا جستجوی اول سطح (BFS) در سی شارپ -------- آشنایی با SignalR در Asp.net core -------- آموزش استفاده از کلاس SeedData در Asp.net Core -------- قالب سایت فروشگاهی -------- آموزش ایجاد برنامه نصب (setup) قسمت سوم -------- آموزش ایجاد برنامه نصب (setup) قسمت دوم -------- آموزش ایجاد برنامه نصب (setup) قسمت اول -------- آموزش عملیات CRUD با استفاده از Ragor Pages در Asp.net Core2.0 -------- آموزش ثبت تصویر توسط دوربین در برنامه نویسی اندروید به زبان c#.net -------- حل مساله n وزیر با استفاده از الگوریتم ژنتیک و بصورت گرافیکی -------- آموزش نمایش تصویر loading در سمت client جهت بارگزاری صفحات با حجم زیاد از سرور در asp.net mvc -------- آموزش اعتبار سنجی غیر همزمان(AsyncValidation) با استفاده از جاوااسکریپت در Asp.net mvc -------- آموزش ایجاد breadcrumb با استفاده از sitemap در MVC -------- آموزش ایجاد برنامه چت دوطرفه با استفاده از Socket در سی شارپ -------- آموزش ارسال و دریافت فایل در برنامه تحت شبکه با استفاده ار سوکت (Socket) -------- آموزش رسم نمودار در Asp.net -------- آموزش ایجاد مگا منو -------- آموزش استفاده از Grid mvc در Asp.net mvc -------- پیاده سازی سیستم احراز هویت کاربران در Asp.net MVC (بخش چهارم) -------- پیاده سازی سیستم احراز هویت کاربران در Asp.net MVC (بخش سوم) -------- پیاده سازی سیستم احراز هویت کاربران در Asp.net MVC (بخش دوم) -------- پیاده سازی سیستم احراز هویت کاربران در Asp.net MVC (بخش اول) -------- بررسی نکات امنیتی در آپلود تصاویر -------- آموزش async - await در یک مثال عملی -------- قالب پنل ادمین --------

ابتدای صفحه