using Microsoft.EntityFrameworkCore; using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; namespace Haoliang.Data.Repositories { public class Repository : IRepository where T : class { protected readonly DbContext _context; protected readonly DbSet _dbSet; public Repository(DbContext context) { _context = context; _dbSet = context.Set(); } public virtual async Task GetByIdAsync(int id) { return await _dbSet.FindAsync(id); } public virtual async Task> GetAllAsync() { return await _dbSet.ToListAsync(); } public virtual async Task> FindAsync(System.Linq.Expressions.Expression> predicate) { return await _dbSet.Where(predicate).ToListAsync(); } public virtual async Task SingleOrDefaultAsync(System.Linq.Expressions.Expression> predicate) { return await _dbSet.SingleOrDefaultAsync(predicate); } public virtual async Task AddAsync(T entity) { await _dbSet.AddAsync(entity); } public virtual async Task AddRangeAsync(IEnumerable entities) { await _dbSet.AddRangeAsync(entities); } public virtual void Update(T entity) { _dbSet.Attach(entity); _context.Entry(entity).State = EntityState.Modified; } public virtual void Remove(T entity) { _dbSet.Remove(entity); } public virtual void RemoveRange(IEnumerable entities) { _dbSet.RemoveRange(entities); } public virtual async Task CountAsync(System.Linq.Expressions.Expression> predicate = null) { return predicate == null ? await _dbSet.CountAsync() : await _dbSet.CountAsync(predicate); } public virtual async Task ExistsAsync(System.Linq.Expressions.Expression> predicate) { return await _dbSet.AnyAsync(predicate); } public virtual async Task SaveAsync() { return await _context.SaveChangesAsync(); } } public class ReadRepository : IReadRepository where T : class { protected readonly DbContext _context; protected readonly DbSet _dbSet; public ReadRepository(DbContext context) { _context = context; _dbSet = context.Set(); } public virtual async Task GetByIdAsync(int id) { return await _dbSet.FindAsync(id); } public virtual async Task> GetAllAsync() { return await _dbSet.ToListAsync(); } public virtual async Task> FindAsync(System.Linq.Expressions.Expression> predicate) { return await _dbSet.Where(predicate).ToListAsync(); } public virtual async Task SingleOrDefaultAsync(System.Linq.Expressions.Expression> predicate) { return await _dbSet.SingleOrDefaultAsync(predicate); } public virtual async Task CountAsync(System.Linq.Expressions.Expression> predicate = null) { return predicate == null ? await _dbSet.CountAsync() : await _dbSet.CountAsync(predicate); } public virtual async Task ExistsAsync(System.Linq.Expressions.Expression> predicate) { return await _dbSet.AnyAsync(predicate); } } public class WriteRepository : IWriteRepository where T : class { protected readonly DbContext _context; protected readonly DbSet _dbSet; public WriteRepository(DbContext context) { _context = context; _dbSet = context.Set(); } public virtual async Task AddAsync(T entity) { await _dbSet.AddAsync(entity); } public virtual async Task AddRangeAsync(IEnumerable entities) { await _dbSet.AddRangeAsync(entities); } public virtual void Update(T entity) { _dbSet.Attach(entity); _context.Entry(entity).State = EntityState.Modified; } public virtual void Remove(T entity) { _dbSet.Remove(entity); } public virtual void RemoveRange(IEnumerable entities) { _dbSet.RemoveRange(entities); } public virtual async Task SaveAsync() { return await _context.SaveChangesAsync(); } } }