2

处理对数据库的重复 linq 查询的正确做法应该是什么?重复查询是指在我的代码中重复出现的此类查询。

例子:

我注意到在我的代码中重复出现以下查询:

dataContext.Users.Where(u =>u.IsActive && u.IsAdmin).OrderByDescent(u => u.Name)

我应该将包含上述查询的方法放在哪里。应该是UserRepository(以这种方式,我可能会以上帝课结束,这是不好的做法)?或者我应该创建类架构来处理这个问题。

我想知道你对此有何看法。以及您认为哪种类结构最通用且最容易重用。

我记得,我可以使用存储过程作为重复查询的地方,但我不想那样做。

4

1 回答 1

1

是的,它可以在. UserRepository_ Godclass_Service LayerExtensionsGetAll()UserRepository

更新
我试图更详细地展示它。

  1. 构建一个通用存储库,其中包含所有用于检索/存储数据的语句。
  2. 创建一个使用/发送到存储库的服务层。
  3. 添加扩展方法以过滤特定结果。(在 c# 3.0 中提供)

一些代码:

// Repository (non-generic)
private IQueryable<User> GetUser()
{
  var results = from u in _db.Users
                select new User
                {
                  ID = u.ID,
                  Username = u.Username,
                  // and so on
                };

  return results;
}


//Service Layer  
private User GetUser(string Username)
{
   User u = _repository.GetUser().WithUsername(username)
                                 .SingleOrDefault();
} 

// Extension Method
public static IQueryable<User> WithUsername(this IQueryable<User> qry, string username)
{
  return from u in qry
         where u.Username == username
         select u;
}

此方法与 Rob Conerys MVC StoreFront Preview 相关。其他项目的实现可能会有所不同,但这是一种方法。

于 2012-08-31T08:59:02.543 回答