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

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


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

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


اخبار و مقالات در فکر بکر آموزش نحوه ریست کردن Migration در EntityFramework

لطفا به ادامه مطالب توجه فرمایید ...


اخبار و مقالات در فکر بکر پیاده سازی مسیریابی با استفاده از الگوریتم پیمایش اول سطح یا جستجوی اول سطح (BFS) در سی شارپ

الگوریتم پیمایش اول سطح یا جستجوی اول سطح (Breadth First Search - BFS) از جمله الگوریتم‌های مشهور پیمایش و جستجوی گراف است که در ...


اخبار و مقالات در فکر بکر آموزش اتصال داده ها بین دو کنترل DropDownList در Asp.netMVC بصورت Ajax

در این قسمت به آموزش اتصال داده ها بین دو کنترل DropDownList مانند آنچه که جهت نمایش شهر ها بر اساس استان انتخاب شده مورد استفاد ...


اخبار و مقالات در فکر بکر آموزش استفاده از Log4net در Asp.net 5

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


اخبار و مقالات در فکر بکر آموزش استفاده از Bundler & Minifier در Asp.Net Core

در این آموزش ابتدا چند فایل استاتیک(css-js) به ویوی برنامه ارجاع میدهیم و سپس با استفاده از مفهوم Bundling and Minifying حجم و تر ...


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

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


اخبار و مقالات در فکر بکر قالب پنل ادمین

جهت دانلود قالب پنل مدیریتی به ادامه مطلب مراجعه نمایید ...


اخبار و مقالات در فکر بکر آموزش اعتبار سنجی غیر همزمان(AsyncValidation) با استفاده از جاوااسکریپت در Asp.net mvc

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


اخبار و مقالات در فکر بکر آموزش استفاده از CQRS و Mediator در Asp.Net Core

قبل ار اینکه به پیاده سازی CQRS بپردازیم کمی به علت استفاده از آن میپردازیم. هدف از استفاده از الگوی CQRS (Command and Query Re ...


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

در این برنامه با استفاده از Socket و پروتکل UDP دو برنامه جهت ارسال و دریافت پیام بصورت دوطرفه ایجاد میکنیم. لطفا به ادامه مطلب ت ...


اخبار و مقالات در فکر بکر دانلود کتاب Entity Framework Code First Succinctly

جهت دانلود کتاب به ادامه مطلب توجه نمایید ...


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

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


اخبار و مقالات در فکر بکر سورس برنامه shutdown - restart - lock - sleep در سی شارپ

سورس بسیار زیبای برنامه shutdown - restart - lock - sleep در سی شارپ را از فکر بکر دانلود نمایید. لطفا به ادامه مطالب توجه نمایید ...


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

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

05TmAh

آموزش کار با کوکی ها (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) --------

ابتدای صفحه