实体框架和按语句的动态排序

时间:2011-12-13 16:26:57

标签: sql entity-framework-4.1

我一直在努力让这个工作。我希望有一个EF声明可以列入一个列。我原来的陈述是这样的:

var Query = from P in DbContext.People
                   where P.BusinessUnits.Any(BU =>BU.BusinessUnitID == businessUnitId)
                   orderby P.LastName
                   select P;

我将此更改为以下内容:

var Query = from P in DbContext.People
                   where P.BusinessUnits.Any(BU =>BU.BusinessUnitID == businessUnitId)
                   orderby sortField
                   select P;

sortField是我们希望排序的列,并且是一个字符串,即LastName。但是,它似乎不起作用,它没有排序,输出的SQL字符串是完全错误的。有人以前有这个工作吗?

2 个答案:

答案 0 :(得分:14)

您可以尝试使用以下类型将表达式传递给您的方法:

Expression<Func<Person, object>> expr = p => p.LastName;

然后使用linq扩展而不是linq表达式...

var Query = 
 DbContext.People
 .Where(P => P.BusinessUnits.Any(BU =>BU.BusinessUnitID == businessUnitId))
 .OrderBy(expr)
 .ToList();

答案 1 :(得分:4)

您的排序不起作用,因为您正在对字符串文字进行排序。这不是非法的,但也不是特别有用。您需要通过IQueryable<T>的API提供排序字段,例如,如下所示:

var q = from P in DbContext.People
   where P.BusinessUnits.Any(BU =>BU.BusinessUnitID == businessUnitId)
   orderby P.LastName
   select P;
if ("sortField".Equals("FirstName"))
    q = q.OrderBy(p => p.FirstName);
else if ("sortField".Equals("LastName"))
    q = q.OrderBy(p => p.LastName);
else if ("sortField".Equals("Dob"))
    q = q.OrderBy(p => p.Dob);