6

所以我得到了这样的东西:

var myObj = db.SomeObject
              .Include("Tasks")
              .SingleOrDefault(x => x.Id == someObjectId);

if (myObj != null)
{
    myObj.Tasks = myObj.Tasks.OrderBy(x => x.Number).ToList();
}

在这里,我希望能够where在我的 Include 上添加一个条件 (),例如: .where task.IsDeleted == false

到目前为止,我还没有找到解决方案。

我知道我可以将where与我订购任务的位置一起使用,但是这不会在数据库上运行,而是使用内存。我希望它在数据库上运行。

这里有人知道我该怎么做吗?如果是这样,是否还有办法将order by条件放入包含的任务列表中?

4

4 回答 4

6

像这样的东西,返回你的原始对象,它的子集合被过滤和排序。

SomeObject a = db.SomeObjects.Where(x => x.Id == someobjectid)
                      .Select(
                          x =>
                          new
                              {
                                  someObject = x,
                                  task = x.Tasks.Where(task => task.IsDeleted == false)
                                                .OrderBy(task => whatever)
                              })
                      .Select(x => x.someObject).Single();

它实际上丢失了最后一次选择中的活动集合,因此您可以这样做:

SomeObject a = db.SomeObjects.Where(x => x.Id == someobjectid)
                      .Select(
                          x =>
                          new
                              {
                                  someObject = x,
                                  task = x.Tasks.Where(task => task.IsDeleted == false)
                                                .OrderBy(task => whatever)
                              });
 return a.FirstOrDefault().someObject;
于 2013-04-04T12:10:50.983 回答
5

要做到这一点是 EF,您需要使用Select子句指定投影。

像这样的东西只会从数据库中获得你想要的数据:

var anonymous = db.SomeObject.Where( x => x.Id == someObjectId )
  .Select( x => new
    {
      SomeObject = x,
      Tasks = x.Tasks
        .Where( o => !o.IsDeleted )
        .OrderBy( o => ... )
    }
  )
  .SingleOrDefault()
;

你最终会得到一个匿名类型的实例,但你可以很容易地在客户端上修复它:

MyObject myObject = anonymous.SomeObject;
myObject.Tasks = anonymous.Tasks;
于 2013-04-04T11:58:04.037 回答
2

简单的答案是:你不能那样做。

为什么?因为你查询SomeObject.
每个返回的数据都SomeObject包含所有引用的数据,因为如果不这样做,它就不会代表数据库中的实际对象。

于 2013-04-04T11:51:55.560 回答
1

分别获得它们怎么样:

var myObj = db.SomeObject
              .SingleOrDefault(x => x.Id == someObjectId);


var tasks = db.SomeObject
              .Where(x => x.Id == someObjectId)
              .SelectMany(x => x.Tasks)
              .Where(x => !x.Deleted);
于 2013-04-04T11:57:23.643 回答