【问题标题】:Order an ICollection [duplicate]订购 ICollection [重复]
【发布时间】:2017-10-03 01:27:39
【问题描述】:

我有一个包含电子邮件集合的用户对象。我想返回上次注册的地址。为此,我制作了一个 DataTable,运行 Select 并按日期排序,但它们是直接使用集合执行此操作的任何其他方式吗?

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

用户

public ICollection<EmailAddress> EmailAddresses { get; set; } = new HashSet<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();

【问题讨论】:

    标签: c# entity-framework-core


    【解决方案1】:

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

    using System.Linq;
    
    EmailAddresses = EmailAddresses.OrderByDescending(r => r.DateCreated).ToList();
    

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

    【讨论】:

      【解决方案2】:

      如果您只想要最后一个注册地址,您可以对列表进行排序,然后使用First(),如下所示:

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

      【讨论】:

      • 但是如何直接将 OrderByDescending 与 List 一起使用?当我需要对列表进行排序时,它可以作为 List
      • List&lt;T&gt; 实现了IEnumerable,因此您可以在其上使用OrderByDescending 扩展方法。您只需在顶部添加using System.Linq
      猜你喜欢
      • 2019-08-12
      • 2017-03-24
      • 1970-01-01
      • 2021-04-14
      • 2018-06-30
      • 1970-01-01
      • 2023-03-10
      • 2015-10-31
      • 1970-01-01
      相关资源
      最近更新 更多