- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
无法理解为什么我的简单订购没有按预期工作。这是有问题的行:
return messages.OrderBy(o => o.MessageType)
.ThenBy(p => p.IsUrgent)
.ThenByDescending(p => p.Timestamp)
.ToList();
最后两个顺序(紧急和时间戳)不能正常工作。我的结果要么按 IsUrgent 要么按时间戳排序,但绝不会同时排序。
我的最终结果应该是所有消息都按类型排序(只有 3 种类型:新建、已保存、已删除)。然后在每种类型中,先有紧急消息,然后按时间戳排序。
更新
你问了更多信息,所以在这里
[TestMethod]
public void Messages_should_sort_correctly()
{
var contact = new Models.Contact(); //just to satisfy the object
var expectedOrder = new string[] { "5", "6", "12", "3", "10", "9", "4", "8", "11", "13", "2", "7", "1" };
var messages = new List<IMessage>
{
new Models.Message { FileName = "1", MessageType = MessageType.Deleted, Timestamp = 31, Contact = contact },
new Models.Message { FileName = "2", MessageType = MessageType.Deleted, Timestamp = 34, Contact = contact },
new Models.Message { FileName = "3", MessageType = MessageType.Inbox, Timestamp = 11, Contact = contact },
new Models.Message { FileName = "4", MessageType = MessageType.Saved, Timestamp = 25, Contact = contact },
new Models.Message { FileName = "5", MessageType = MessageType.Inbox, Timestamp = 14, Contact = contact, IsUrgent = true },
new Models.Message { FileName = "6", MessageType = MessageType.Inbox, Timestamp = 13, Contact = contact, IsUrgent = true },
new Models.Message { FileName = "7", MessageType = MessageType.Deleted, Timestamp = 32, Contact = contact },
new Models.Message { FileName = "8", MessageType = MessageType.Saved, Timestamp = 22, Contact = contact },
new Models.Message { FileName = "9", MessageType = MessageType.Saved, Timestamp = 23, Contact = contact, IsUrgent = true },
new Models.Message { FileName = "10", MessageType = MessageType.Saved, Timestamp = 24, Contact = contact, IsUrgent = true },
new Models.Message { FileName = "11", MessageType = MessageType.Saved, Timestamp = 21, Contact = contact },
new Models.Message { FileName = "12", MessageType = MessageType.Inbox, Timestamp = 12, Contact = contact },
new Models.Message { FileName = "13", MessageType = MessageType.Deleted, Timestamp = 33, Contact = contact, IsUrgent = true }
};
messageServiceMock.Setup(m => m.GetAllMessagesAsync()).Returns(Task.FromResult(messages as IList<IMessage>)).AtMostOnce();
var result = service.Messages; //this property returns the messages from our mock, and then sorts and orders
var actualOrder = result.Select(m => m.FileName);
//expected order "5", "6", "12", "3", "10", "9", "4", "8", "11", "13", "2", "7", "1"
//actual order "12", "3", "5", "6", "4", "8", "11", "10", "9", "2", "7", "1", "13"
Assert.IsTrue(actualOrder.SequenceEqual(expectedOrder));
}
这就是所有魔法/困惑发生的地方
private List<Domain.Interfaces.IMessage> messages = new List<Domain.Interfaces.IMessage>();
public IList<Domain.Interfaces.IMessage> Messages
{
get
{
if (!messages.Any())
{
messages = messageService.GetAllMessagesAsync().Result.ToDomain().ToList();
}
return messages.OrderBy(o => o.MessageType).ThenBy(p => p.IsUrgent == true).ThenByDescending(p => p.Timestamp).ToList();
}
}
最佳答案
理论上它应该按预期工作。您可以使用以下方式跟踪您的查询:
IQueryable<Message> query = messages
.OrderBy(o => o.MessageType)
.ThenBy(p => p.IsUrgent)
.ThenByDescending(p => p.Timestamp);
//debug query.ToString() to see the generated sql
//should be SELECT XXX WHERE YYY ORDER BY MessageType, IsUrgent, Timestamp DESC
return query.ToList();
关于c# - OrderBy().ThenBy().ThenBy() 未在实体列表上给出预期结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35690709/
无法理解为什么我的简单订购没有按预期工作。这是有问题的行: return messages.OrderBy(o => o.MessageType) .ThenBy(p =
我有以下方法: public List defaultSortExpressions { get; set; } private IQueryable orderEntries(IQueryable
我正在尝试添加 ThenById() 方法,该方法将在调用 IOrderedQueryable 上的 OrderBy() 后启动: public static IOrderedQueryable Th
我有一个查询应该这样排序: var list = new List(); var orderedList = list .OrderByDescending(x => x.Project)
灵感来自 this我做了这个: ISortable public interface ISortable { IPageable OrderBy(Expression> orderBy);
我正在使用以下查询语法 from table where where orderby orderby 其中第一个 orderby 是一个日期,第二个 orderby 是一个日期。我认为这将像 orde
谁能解释一下两者之间的区别: tmp = invoices.InvoiceCollection .OrderBy(sort1 => sort1.InvoiceOwner.L
我正在构建一个 Spec Evaluator,它必须考虑多个可能的 OrderBy,如下例所示: if (spec.Order != null) { var count = spec.Orde
我必须编写 Linq 的“立即”模式实现(由于 Unity/Mono 的内存分配限制 - 长话短说,并不重要)。 在我来到 ThenBy 之前,我对所有性能与真正的 Linq 一样快或更快的东西感到满
我正在尝试对绑定(bind)到多个属性的 View 模型进行排序。问题是第二个属性可能为空,我得到一个空引用异常。 return this.People .OrderBy(x => x.Car.N
我有一个包含 50 个元素的点列表,我想对它们进行排序,所以我使用了 orderby thenby to,但我的输出似乎是错误的。第一个元素相应地排序,但接下来的元素是错误的,这是一个屏幕截图。 正确
F# 中是否有任何类似于 LINQ fluent 语法的函数用于按多个表达式排序: myList.OrderBy(fun x->x.Something).ThenBy(fun x->x.Somethi
我正在使用 .NET 4.5,我想了解以下内容: 如果我执行此操作,一切都会按预期进行: Dim lst = Enumerable.Range(1, 10) Dim lstOrdered =
我有一个带有 OrderBy 和 ThenBy 的 linq 查询(与数据库无关) var sortedList = unsortedList .OrderBy(foo
我正在尝试根据先前排好序的列对表格的多个列进行排序。它适用于前两列。但是,一旦我对第三列进行排序,第二列就会失去排序。据我所知,我的 foreach 循环一定有问题。这是我的排序代码: public
我正在尝试按日期对列表进行排序,然后按描述名称对列表进行排序,但是我需要所有具有特定描述的元素成为每个日期的顶部元素。 示例: 01-02-2014 "Description A" 01-02-201
我正在将我的一个项目从使用基于 SQL Server 的 Entity Framework 模型转换为使用本地 SQLite 数据库。到目前为止一切顺利,但由于某种原因我无法对多列查询进行排序。例如:
我有一个独特的情况,我试图在 IQueryable 上执行 .OrderBy。 (如果我的定义不准确,请原谅我) 我有以下内容: IQueryable data = e.Sources.Where(e
我正在 Lua 中实现 LINQ 克隆,但这在这里不太相关,而且我已经完成了大部分功能(可枚举/可查询,还不是预编译器),但想不出一个聪明的实现方式OrderBy 的 ThenBy。 目前我排序一次,
我在我的项目中使用 Linq 和 Lambda 操作,我需要根据类的两个属性对列表进行排序。因此,我使用了 OrderBy().ThenBy() 方法如下: class ValueWithIndex{
我是一名优秀的程序员,十分优秀!