C# Asp.net Membership.GetAllUsers order by email

2019-06-25 19:10发布

I am using Membership.GetAllUsers() to get my user list. I would like to have the list returned sorted by email address as I need to flag some accounts with duplicate emails.

Membership.GetAllUsers() seems to order by username by default. Is there a way to change this behavior?

3条回答
何必那么认真
2楼-- · 2019-06-25 19:23

If you can live with a generic list rather than a MembershipUserCollection:

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

Use OrderBy(x => x.Email, StringComparer.OrdinalIgnoreCase) if you want a case-insensitive sort of the email address.

Membership code actually predates generics (it was integrated into .NET 2.0 from a .NET 1.1 development), hence MembershipUserCollection does not implement generic interfaces.

Given your earlier question, you may be interested in other LINQ-style manipulations. For example the following will give you a dictionary whose keys are email addresses (case-insensitive), and whose values are lists of corresponding MembershipUser objects, sorted by last activity date descending:

var dictionary = Membership.GetAllUsers().Cast<MembershipUser>()
    .GroupBy(x => x.Email, StringComparer.OrdinalIgnoreCase)
    .ToDictionary(
                  x => x.Key, 
                  x =>x.OrderByDescending(u => u.LastActivityDate).ToList()
                 );
查看更多
看我几分像从前
3楼-- · 2019-06-25 19:26

The following code should do it, but it may not have the best performance.

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

It does the sorting in memory, rather than as a db query.

查看更多
不美不萌又怎样
4楼-- · 2019-06-25 19:34
Membership.GetAllUsers().OrderBy(user => user.Email).ToList();
查看更多
登录 后发表回答