我正在使用 Membership.GetAllUsers() 来获取我的用户列表。我希望返回的列表按电子邮件地址排序,因为我需要标记一些具有重复电子邮件的帐户。
Membership.GetAllUsers() 似乎默认按用户名排序。有没有办法改变这种行为?
我正在使用 Membership.GetAllUsers() 来获取我的用户列表。我希望返回的列表按电子邮件地址排序,因为我需要标记一些具有重复电子邮件的帐户。
Membership.GetAllUsers() 似乎默认按用户名排序。有没有办法改变这种行为?
如果您可以使用通用列表而不是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()
);
下面的代码应该可以做到,但它可能没有最好的性能。
Membership.GetAllUsers().Cast<MembershipUser>().OrderBy(m => m.Email);
它在内存中进行排序,而不是作为数据库查询。
Membership.GetAllUsers().OrderBy(user => user.Email).ToList();