我使用Membership.GetAllUsers()来获取我的用户列表。我希望按电子邮件地址排序返回列表,因为我需要使用重复的电子邮件标记一些帐户。
Membership.GetAllUsers()似乎默认按用户名排序。有没有办法改变这种行为?
答案 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();