首页 > 其他 > 详细

linq 两个字段排序

时间:2014-03-27 16:42:00      阅读:447      评论:0      收藏:0      [点我收藏+]

在linq中排序方法有:

OrderBy()         --对某列升序排序

ThenBy()          --某列升序后对另一列后续升序排序

OrderByDescending()  --对某列降序排序

ThenByDescending()   --某列降序后对另一列后续降序排序

举例:

1.现在对集合AllSubjectList按字段column1升序排序后,再按照column2升序排序

<1. var lvThirdSubList =AllSubjectList.OrderBy(m => m.column1).ToList().OrderBy(m=>m.column2).ToList();

<2. var lvThirdSubList =AllSubjectList.OrderBy(m => m.column1).OrderBy(m=>m.column2).ToList();

如果你的vs装了resharper,第二个写法会提示(但不影响排序效果)

"multiple sequential ‘OrderBy‘ invocation is meaningless. Possible ‘ThenBy‘ means"

译为:多个顺序为基准进行排序的调用是没有意义的。可能“ThenBy”的意思,就是说第二个OrderBy可以改为ThenBy

<3. var lvThirdSubList =AllSubjectList.OrderBy(m => m.column1).ThenBy(m=>m.column2).ToList();

 

2.现在对集合AllSubjectList按字段column1升序排序后,再按照column2降序排序

<1. var lvThirdSubList =AllSubjectList.OrderBy(m => m.column1).ToList().OrderByDescending(m=>m.column2).ToList();

<2. var lvThirdSubList =AllSubjectList.OrderBy(m => m.column1).OrderByDescending(m=>m.column2).ToList();

同样这里也会提示(但不影响排序效果)

"multiple sequential ‘OrderBy‘ invocation is meaningless. Possible ‘ThenByDescending‘ means"

[错误]<3. var lvThirdSubList =AllSubjectList.OrderBy(m => m.column1).ThenByDescending(m=>m.column2).ToList();

这种写法结果按照column1,column2升序排序,跟1.<1效果一样。ThenByDescending(ThenBy)不能这样用。

ThenBy只能跟在OrderBy后面,ThenByDescending只能跟在OrderByDescending后面。

 

linq 两个字段排序,布布扣,bubuko.com

linq 两个字段排序

原文:http://www.cnblogs.com/paulhe/p/3625397.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!