pro*_*707 2 c# linq repository-pattern
我们想要创建一个通用函数,它只选择所需的列而不是返回整个实体.例如,我有一个具有以下属性的Country类.
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public int CountryId { get; set; }
[Required]
public string Name { get; set; }
public int CreatedBy {get;set;}
public DateTime CreatedDate {get;set;}
Run Code Online (Sandbox Code Playgroud)
我有一个呼吸类,这对所有实体都很常见.
public class Repository<T> : IRepository<T> where T : class
{
DbContext db;
DbSet<T> currentEntity;
public Repository(DbContext db)
{
this.db = db;
currentEntity = db.Set<T>();
}
public void Add(T TEntity)
{
currentEntity.Add(TEntity);
}
public virtual List<T> GetAll()
{
return currentEntity.ToList<T>();
}
}
Run Code Online (Sandbox Code Playgroud)
因为GetAll方法返回所有列,但我想只选择Name和CountryId.如何创建只返回所需数据的通用函数?
首先,您需要在通用存储库中添加通用方法:
public class Repository<T> : IRepository<T> where T : class
{
DbContext db;
DbSet<T> currentEntity;
public Repository(DbContext db)
{
this.db = db;
currentEntity = db.Set<T>();
}
public void Add(T TEntity)
{
currentEntity.Add(TEntity);
}
public virtual List<T> GetAll()
{
return currentEntity.ToList<T>();
}
public ICollection<TType> Get<TType>(Expression<Func<T, bool>> where, Expression<Func<T, TType>> select) where TType : class
{
return currentEntity.Where(where).Select(select).ToList();
}
}
Run Code Online (Sandbox Code Playgroud)
现在,你可以调用这个方法.例:
public void SomeService()
{
var myData = Repository.Get(x => x.CountryId > 0, x => new { x.CountryId, x.Name });
foreach (var item in myData)
{
var id = item.CountryId;
var name = item.Name;
// ...
}
}
Run Code Online (Sandbox Code Playgroud)
最后 - 您需要运行时创建lambda表达式和运行时获取必填字段.也许这篇文章可以帮助你:在运行时创建一个带有新匿名类型的lambda表达式,如何在运行时读取类的属性? ps sory我的英语不好=)
| 归档时间: |
|
| 查看次数: |
2673 次 |
| 最近记录: |