订购ICollection

时间:2017-10-03 01:27:39

标签: c# entity-framework-core

我有一个带有电子邮件集合的用户对象。我想退回最后一个注册地址。要做到这一点,我制作了一个DataTable,在日期运行Select和order,但他们是否可以直接使用该集合进行任何其他方式?

基本上我想要的是[0]位置的地址是最后注册的。我可以通过ICollection实现这个目标,还是应该使用其他东西?

用户

public ICollection<EmailAddress> EmailAddresses { get; set; } = new HashSet<EmailAddress>();

EmailAddress的

public DateTime DateCreated { get; set; }
public int UserId { get; set; }
public string Address { get; set; }
public DateTime DateLastInvoked { get; set; } = DateTime.Now;
public int LastInvokedByClientId { get; set; }

解决方案

EmailAddress result = this.EmailAddresses.Where(adr => adr.Active.Equals(true)).OrderByDescending(dt => dt.DateCreated).First();

2 个答案:

答案 0 :(得分:4)

查找LINQ。还有更基本的linq查询操作。

using System.Linq;

EmailAddresses = EmailAddresses.OrderByDescending(r => r.DateCreated).ToList();

这将按降序排列您的收藏。

答案 1 :(得分:1)

如果您只想要上次注册的地址,请对列表进行排序,然后使用First(),如下所示:

var lastRegisteredAddress = EmailAddresses.OrderByDescending( a => a.DateCreated ).First();