在linq查询中切换案例

时间:2015-01-27 08:25:40

标签: c# linq

如何在相应的linq中将foreach语句转换为可能的空值处理:

foreach (var val in userData.ManagedUsers.Values)
        {
            if (val.UserId == userId)
            {
                foreach (var role in val.Roles)
                {
                    switch (role.ToLower())
                    {
                        case "underwriter1":
                            return "1";
                        case "underwriter2":
                            return "2";
                        case "underwriter3":
                            return "3";
                    }
                }
            }
        }

1 个答案:

答案 0 :(得分:4)

你可以用这个:

string result = userData.ManagedUsers.Values
    .Where(u => u.UserId == userId)
    .SelectMany(u => u.Roles)
    .Select(r => {
        if(String.Equals(r, "underwriter1", StringComparison.InvariantCultureIgnoreCase))
            return "1";
        else if(String.Equals(r, "underwriter2", StringComparison.InvariantCultureIgnoreCase))
            return "2";
        else if(String.Equals(r, "underwriter3", StringComparison.InvariantCultureIgnoreCase))
            return "3";
        else return null; 
    }).First(r => r != null);

我在这里不使用switch,因为您需要使用ToLower来区分不区分大小写。那时你没有通过turkey test。因此,我String.Equals使用InvariantCultureIgnoreCase,效率更高,处理Rolenull的情况。

顺便说一句,如果我理解你的逻辑,这似乎会更好:

 string result = userData.ManagedUsers.Values
     .Where(u => u.UserId == userId)
     .SelectMany(u => u.Roles)
     .Select(r => r != null && r.StartsWith("underwriter") ? r.Substring("underwriter".Length) : null)
     .First();