sql – 实体框架和按语句的动态顺序

前端之家收集整理的这篇文章主要介绍了sql – 实体框架和按语句的动态顺序前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我一直在努力让这个工作.我希望有一个EF声明可以列入一个列.我原来的陈述是这样的: @H_404_2@var Query = from P in DbContext.People where P.BusinessUnits.Any(BU =>BU.BusinessUnitID == businessUnitId) orderby P.LastName select P;

我将此更改为以下内容

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

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

解决方法

您可以尝试使用以下类型将表达式传递给您的方法: @H_404_2@Expression<Func<Person,object>> expr = p => p.LastName;

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

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

猜你在找的MsSQL相关文章