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

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


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

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


اخبار و مقالات در فکر بکر آموزش ساخت صفحه Page Not Found (404) در Aspnet core

در این بخش به اموزش نحوه مدیریت خطا و هدایت کاربر به صفحه Page Not Found (404) در Aspnet core می پردازیم. یکی از مشکلات مهمی ک ...


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

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


اخبار و مقالات در فکر بکر آموزش کامل Web Api2 در MVC با عملیات CRUD

با سلام خدمت تمامی کاربران فکر بکر در این مقاله سعی نمودم تا با ارائه مثال عملی به آموزش کامل Web Api بپردازم. قبل از هرچیز باید ...


اخبار و مقالات در فکر بکر آموزش ساخت صفحه تماس با ما بصورت Ajax در Asp.net MVC5

در این برنامه می خواهیم به آموزش نحوه ارسال اطلاعات بدون لود یا refresh شدن صفحه به سمت سرور در Asp.net MVC بپردازیم. ...


اخبار و مقالات در فکر بکر آموزش نحوه استفاده از Ckeditor با قابلیت آپلود تصاویر در Asp.net mvc

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


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

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


اخبار و مقالات در فکر بکر آموزش پیاده سازی UnitOfWork در Asp.net Core قسمت اول

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


اخبار و مقالات در فکر بکر سورس استفاده از کامپوننت Roxy File manager در Asp.net core

در این سورس شما با نحوه استفاده از کامپوننتهای ckeditor و Roxy File manager در Asp.net core اشنا خواهید شد. جهت دانلود بر روی ادا ...


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

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


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

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


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

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


اخبار و مقالات در فکر بکر نتیجه تحقیق جهانی از بیش از 50000 توسعه دهنده برنامه در 173 کشور منتشر شد

به نقل از لنفورماتیسین, Stack Overflow اطلاعات بیش از پنجاه هزار توسعه دهنده برنامه در 173 کشور را گرد اورده و اماری تهیه کرده اس ...


اخبار و مقالات در فکر بکر نحوه خواندن اطلاعات از فایل appsetting.json در Asp.net Core

فایل appsetting در نسخه های core معادل فایل webconfig در نسخه های قدیمی تر می باشد که برای پیکر بندی تنظیمات کلی پروژه مانند تنظی ...


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

موفق باشید

0rf9zh

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

ابتدای صفحه