加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

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

发布时间:2020-12-12 07:29:40 所属栏目:MsSql教程 来源:网络整理
导读:我一直在努力让这个工作.我希望有一个EF声明可以列入一个列.我原来的陈述是这样的: var Query = from P in DbContext.People where P.BusinessUnits.Any(BU =BU.BusinessUnitID == businessUnitId) orderby P.LastName select P; 我将此更改为以下内容: var
我一直在努力让这个工作.我希望有一个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字符串是完全错误的.有人以前有这个工作吗?

解决方法

您可以尝试使用以下类型将表达式传递给您的方法:
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();

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读