4

我正在使用 Membership.GetAllUsers() 来获取我的用户列表。我希望返回的列表按电子邮件地址排序,因为我需要标记一些具有重复电子邮件的帐户。

Membership.GetAllUsers() 似乎默认按用户名排序。有没有办法改变这种行为?

4

3 回答 3

11

如果您可以使用通用列表而不是MembershipUserCollection

Membership.GetAllUsers().Cast<MembershipUser>().OrderBy(x => x.Email).ToList();

如果OrderBy(x => x.Email, StringComparer.OrdinalIgnoreCase)您想要不区分大小写的电子邮件地址,请使用此选项。

成员资格代码实际上早于泛型(它是从 .NET 1.1 开发集成到 .NET 2.0 中的),因此MembershipUserCollection不实现泛型接口。

鉴于您之前的问题,您可能对其他 LINQ 样式的操作感兴趣。例如,以下将为您提供一个字典,其键是电子邮件地址(不区分大小写),其值是相应MembershipUser对象的列表,按上次活动日期降序排序:

var dictionary = Membership.GetAllUsers().Cast<MembershipUser>()
    .GroupBy(x => x.Email, StringComparer.OrdinalIgnoreCase)
    .ToDictionary(
                  x => x.Key, 
                  x =>x.OrderByDescending(u => u.LastActivityDate).ToList()
                 );
于 2012-07-06T17:23:36.747 回答
2

下面的代码应该可以做到,但它可能没有最好的性能。

Membership.GetAllUsers().Cast<MembershipUser>().OrderBy(m => m.Email);

它在内存中进行排序,而不是作为数据库查询。

于 2012-07-06T17:30:38.963 回答
1
Membership.GetAllUsers().OrderBy(user => user.Email).ToList();
于 2012-07-06T17:21:11.067 回答