C# List Orderby

yxy10072510329 2010-08-04 04:41:06
var oneGroupChapterList = chapterList.Where(x => x.ProviderId == oneGroup.Key.ProviderId && x.BookId == oneGroup.Key.BookId).ToList<BookChapterInfo>();
List<BookChapterInfo> allChapter = oneGroupChapterList.OrderBy(c => new { c.DisplayOrder, c.ChapterId }).ToList<BookChapterInfo>();


异常信息:At least one object must implement IComparable.,也就是在OrderBy的时候出的异常,谁知道为什么在线等。。
...全文
1605 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
yxy10072510329 2010-08-04
  • 打赏
  • 举报
回复
yizhili正解,其他童鞋说的可能与我的情况不大对口,结贴给分,谢谢大家!
wanghui0380 2010-08-04
  • 打赏
  • 举报
回复
OrderBy(c => new { c.DisplayOrder, c.ChapterId })

orderby 只允许使用值类型,或已实现了IComparable接口的对象
yizhili 2010-08-04
  • 打赏
  • 举报
回复
.NET 不知道 new { c.DisplayOrder, c.ChapterId } 要如何排序
如果要双关键字排序可以用 OrderBy( c=>c.DisplayerColor ).ThenBy( c=>c.ChaptherId )
Peter200694013 2010-08-04
  • 打赏
  • 举报
回复
相应类实现IComparable接口
gomoku 2010-08-04
  • 打赏
  • 举报
回复
List<BookChapterInfo> allChapter = oneGroupChapterList.OrderBy(c => c.DisplayOrder * 1000000L + c.ChapterId ).ToList<BookChapterInfo>();
q107770540 2010-08-04
  • 打赏
  • 举报
回复
var oneGroupChapterList = chapterList.Where(x => x.ProviderId == oneGroup.Key.ProviderId && x.BookId == oneGroup.Key.BookId);
List<BookChapterInfo> allChapter = oneGroupChapterList.OrderBy(c => new { c.DisplayOrder, c.ChapterId }).ToList<BookChapterInfo>();

去掉第一句的.ToList<BookChapterInfo>();
它破坏了 linq 的延迟查询 ,影响了效率

110,571

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧