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

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


مطالب تصادفی
اخبار و مقالات در فکر بکر آشنایی با مفهوم Generic در C#.net

Generics یکی از ویژگی های قدرتمند برای بسیاری از زبان های برنامه نویسی از جمله C# است. که به شما امکان می دهد کدی بنویسید که می ...


اخبار و مقالات در فکر بکر حل تمرین مسائل برنامه نویسی از بخش رویدادهای کیبورد (Windows Form) در سی شارپ

جهت مشاهده سوال و دانلود سورس آن لطفا به ادامه مطلب توجه نمایید. ...


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

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


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

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


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

در این برنامه سورس notepad در c# را بصورت رایگان برای شما کاربران عزیز در فکر بکر جهت دانلود قرار دادیم ...


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

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


اخبار و مقالات در فکر بکر آموزش ثبت تصویر توسط دوربین در برنامه نویسی اندروید به زبان c#.net

در این آموزش به نحوه ثبت تصویر و ذخیره آن در حافظه گوشی با سیستم عامل اندروید با زبان برنامه نویسی سی شارپ (C#.net)خواهیم پرداخت. ...


اخبار و مقالات در فکر بکر عملیات crud و WebApi در Asp.net 6

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


اخبار و مقالات در فکر بکر آموزش publish کردن برنامه های Asp.net core بر روی سرور iis

در این آموزش ابتدا یک پروژه ساده با استفاده از asp.net core 2.1 ایجاد میکنیم و سپس آنرا بر روی سرور iis قرار خواهیم داد. ...


اخبار و مقالات در فکر بکر آموزش ویرایش مطالب با استفاده از x-editable در Asp.net MVC

کتابخانه جاوااسکریپتی x-editable دارای قابلیتهای بسیار خوبی برای برنامه نویسان میباشد و همچنین با قابلیتی که دارد شما میتوانید ب ...


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

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


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

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


اخبار و مقالات در فکر بکر مروری بر Identity در Asp.net core2.1 (بخش دوم)

ASP.NET Core Identity یک سیستم جامع جهت مدیریت کاربران و نقشها و همینطور ورود و خروج در برنامه های ASP.NET Core می باشد. در این آ ...


اخبار و مقالات در فکر بکر آموزش نحوه ایجاد Model برای دیتابیس موجود در Entity Framework Core

در این آموزش به نحوه ایجاد کلاسهای context و entity برای دیتابیس موجود در Entity Framework Core خواهیم پرداخت. ...


پیوندها
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

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

XcG81b

آموزش کار با کوکی ها (Cookie) در Asp.net core -------- آموزش رمزنگاری فایلها در asp.net core -------- مقایسه واحدهای اندازه گیری rem و em در css -------- آشنایی با مفهوم Generic در C#.net -------- نحوه خواندن اطلاعات از فایل appsetting.json در Asp.net Core -------- آموزش استفاده از CQRS و Mediator در Asp.Net Core -------- نحوه ایجاد image checkbox در html css -------- عملیات crud و WebApi در Asp.net 6 -------- آموزش ایجاد custom model binder در Asp.net core -------- آموزش استفاده از Log4net در Asp.net 5 -------- آموزش پیاده سازی 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) --------

ابتدای صفحه