步骤1:创建仓储接口。在仓储接口中定义基本的CRUD操作以及搜索方法。
public interface IRepository
步骤2:实现仓储接口。实现所有的基本CRUD操作以及搜索方法。在搜索方法中使用TrimStart方法来去除搜索关键字开头和结尾的空格。
public class Repository
public Repository(AppDbContext dbContext)
{
_dbContext = dbContext;
}
public async Task GetByIdAsync(int id)
{
return await _dbContext.Set().FindAsync(id);
}
public async Task> GetAllAsync()
{
return await _dbContext.Set().ToListAsync();
}
public async Task CountAsync()
{
return await _dbContext.Set().CountAsync();
}
public async Task AddAsync(T entity)
{
await _dbContext.Set().AddAsync(entity);
await _dbContext.SaveChangesAsync();
}
public async Task UpdateAsync(T entity)
{
_dbContext.Set().Update(entity);
await _dbContext.SaveChangesAsync();
}
public async Task DeleteAsync(T entity)
{
_dbContext.Set().Remove(entity);
await _dbContext.SaveChangesAsync();
}
public async Task> SearchAsync(Expression> predicate)
{
return await _dbContext.Set().Where(predicate).ToListAsync();
}
}
步骤3:在服务中使用仓储类。在应用程序服务中注入仓储类,并使用仓储类中定义的方法进行搜索操作。在搜索关键字输入时使用TrimStart方法去除开头和结尾的空格。
public class ProductService : IProduct