C#Asp.net Membership.GetAllUsers通过电子邮件订购

时间:2012-07-06 17:18:00

标签: c# asp.net asp.net-mvc-2

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

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

3 个答案:

答案 0 :(得分:11)

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

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

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

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

鉴于your earlier question,您可能对其他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()
                 );

答案 1 :(得分:2)

以下代码应该这样做,但可能没有最佳性能。

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

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

答案 2 :(得分:1)

Membership.GetAllUsers().OrderBy(user => user.Email).ToList();