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

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


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

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


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

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


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

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


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

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


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

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


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

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


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

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


اخبار و مقالات در فکر بکر آشنایی با Asp.net mvc6 بصورت پروژه عملی #1

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


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

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


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

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


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

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


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

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


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

با سلام - در این مقاله به آموزش نحوه استفاده از کنترل PersianDateTimePicker(تقویم فارسی) در برنامه های تحت وب می پردازیم ...


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

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


پیوندها
5 (21)

Repository یک مخزن یا انباره ای میباشد که میتواند بعنوان لایه DAL در برنامه نویسی مورد استفاده قرار گیرد.در این مثال قصد داریم برای اطلاعات User با استفاده از Repository عملیات CRUD را انجام دهیم
گروه : Asp.net MVC
تاریخ انتشار: 1395/05/20

فکر بکر

Repository یک مخزن یا انباره ای میباشد که میتواند بعنوان لایه DAL در برنامه نویسی مورد استفاده قرار گیرد.

در این مثال قصد داریم برای اطلاعات User با استفاده از  Repository عملیات CRUD را انجام دهیم.

ابتدا یک پروژه از نوع Empty MVC ایجاد نمایید.
یک کلاس به نام User درون پوشه Models ایجاد نمایید و محتویات آنرا بصورت زیر ویرایش کنید.

 


namespace RepositorySample.Models
{
    public class User
    {
        public int ID { get; set; }
        public string Fname { get; set; }
        public string Lname { get; set; }
        public string Email { get; set; }
        public bool IsActive { get; set; }
        public string UserName { get; set; }
        public string Password { get; set; }
    }
}

 

 روی نام پروژه کلیک راست نمایید و گزینه Manage Nuget Packages ر ا انتخاب نمایید از صفحه باز شده از قسمت Brows عبارت EntityFrameWork را جستجو و سپس نصب نمایید.

entityframework

 

درون پوشه Models کلاسی بنام DBContext ایجاد نمایید و محتویات آنرا بصورت زیر ویرایش نمایید.


namespace RepositorySample.Models
{
    public class DBContext : DbContext
    {
        public DBContext():base("mycon")
        {

        }
         static DBContext()
        {

        }
        public DbSet<User> user
        {
            get; set;
        }
    }
}

 

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

<connectionStrings>
    <add name="mycon" connectionString="data source=.;initial catalog=repositoryDB;integrated security =true;" providerName="System.Data.SqlClient" />
  </connectionStrings>

 

 رشته اتصال فوق را بر اساس سیستم خود تنظیم نمایید.
پوشه ای بنام DAL به روت برنامه اضافه نمایید و کلاسی بنام IUserRepository ایجاد نمایید و سپس اینترفس زیر را درون آن درج نمایید.


namespace RepositorySample.DAL
{
    public interface IUserRepository
    {
       IEnumerable<Models.User> GetUser();
        Models.User GetUserByID(int id);
        void DeleteUser(int userID);
        void InsertUser(Models.User user);
        void UpdateUser(Models.User user);
        void Save();
    }
   
}

 

سپس کلاسی دیگر بنام UserRepository  را درون پوشه DAL اضافه نمایید و محتویات آنرا بصورت زیر ویرایش نمایید.


namespace RepositorySample.DAL
{
    public class UserRepository : IUserRepository,IDisposable
    {
        public UserRepository(Models.DBContext dbcontext)
        {
            db = dbcontext;
        }
        Models.DBContext db = new Models.DBContext();

        IEnumerable<Models.User> IUserRepository.GetUser()
        {
            return db.user.ToList();
        }

        public Models.User GetUserByID(int id)
        {
            return db.user.Find(id);
        }

        public void DeleteUser(int userID)
        {
            User user = db.user.Find(userID);
            db.user.Remove(user);
        }

 

        void IUserRepository.InsertUser(Models.User user)
        {
            db.user.Add(user);
        }

        public void UpdateUser(User user)
        {
            db.Entry(user).State = System.Data.Entity.EntityState.Modified;
        }

        void IUserRepository.Save()
        {
            db.SaveChanges();
        }

        private bool disposed = false;

        protected virtual void Dispose(bool disposing)
        {
            if (!this.disposed)
            {
                if (disposing)
                {
                    db.Dispose();
                }
            }
            this.disposed = true;
        }

        public void Dispose()
        {
            Dispose(true);
            GC.SuppressFinalize(this);
        }
    }

}

 

 

اکنون میتوانید از این کلاس درون کنترلرهای خود استفاده نمایید.
قطعه کد زیر نحوه استفاده از این کلاس در کنترلر Home می باشد.

 

  public class HomeController : Controller

    {

        DAL.IUserRepository userRepository;

        public HomeController() { this.userRepository = new DAL.UserRepository(new Models.DBContext()); }

        public HomeController(DAL.IUserRepository userRepository) { this.userRepository = userRepository; }

        // GET: Home

        public ActionResult Index()

        {

            return View(userRepository.GetUser());

        }

    }

 

JALAL
|
1396/10/18

MERCCC
محمد مهدوی
|
1396/10/30

خواهش میکنم - موفق باشید

حسن
|
1396/11/28

آفرین منم دنبال مفهوم ریپوزوتری بودم سایت شما کمک کرد
محمد مهدوی
|
1396/12/02

موفق باشید

cbp9rE

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

ابتدای صفحه