3

我遇到了一些在 LINQ 中根本无法运行的代码的问题,但它确实可以作为一个简单的 for..each 来运行。任何解释和解决方案将不胜感激。

我有 3 个类,用户,用户,用户权限组成如下:

类用户

ObservableCollection<User> GetList

类用户

Public int id  {get;set;}
Public string UserName  {get;set;}
Public UserPermissions Permissions {get;set;}

类用户权限

Public Int ID {get;set;}
Public int ApplicationID {get;set;}

这有效并返回正确的用户:

Users users = new Users();
foreach (User u in users.GetList() )
{
    if (u.UserName==username && u.Permissions.ApplicationID == applicationId)
    {
        usr = u;
        break;
    }
}

下面的 linq“应该”做同样的事情,但事实并非如此。输出窗口中没有返回或引发错误,并且 muser 变量在跨过它之后根本不存在。我尝试在我的演员表中更具体并使用 AsQueryable。我什至尝试使用两个 from 命令让 p=u.Permissions,但似乎没有任何解决方法。

我担心我的其他类会因此受到影响,并在以后使用更复杂的查询时引起问题。

var  musers = from Users.User u in UsersList
               where (u.UserName==userName) 
                       && (u.Permissions.ApplicationID == ApplicationId)
              select u.ID;

还有一点信息是以下错误吗?

var t1 = UsersList.SelectMany(u => u.Permissions);

错误 1 ​​无法从用法中推断方法“System.Linq.Enumerable.SelectMany(System.Collections.Generic.IEnumerable, System.Func>)”的类型参数。尝试明确指定类型参数。

4

2 回答 2

2
        var usr = users.GetList()
            .FirstOrDefault(
                p => p.UserName == username 
                    && p.Permissions.ApplicationID == applicationId);

实际上应该为你做。如果没有找到用户,FirstOrDefault 可以返回 null...

于 2013-09-23T13:56:45.283 回答
0

亚当是现场谢谢你亚当。

我在调试器中看到 'var found=from...' 表明 found 已创建并在运行 linq 语句的位置包含一个值。但是,正如 Adam 正确指出的那样,linq 枚举被推迟到您枚举查询的那一刻。对我来说这一切看起来都很好的原因是,直接在有效的代码下是一个 for 循环,它触发 THAT linq 查询的枚举。上面的其他人都没有这样的枚举,就好像他们默默地失败了一样!

我认为编译器正在优化该函数,以便我可以在代码中的点而不是枚举发生的位置调试 linq 查询,这是一个不错的技巧,但它完全错误地让我走错了路!哈哈。这让我认为,即使在使用 ToList()、Count() 或其他枚举函数之前结果不可用,查询本身也会在某种程度上进行评估。

例如,在下面的代码中,只有 f3 将包含任何内容,其他的只是,好吧,什么都没有,因为它们从未被枚举!

var f1 = 从.....;

var f2 = 来自 ....;

var f3 = 来自 ....;

做很多其他的事情,甚至调用一个函数

int count = f3.Count();

有趣的是,即使在行运行之后 f1,f2 也没有,但 f3 在枚举(计数)发生之后和之前都有一个值,所以我认为编译器优化/调试在这里发挥了作用。

希望这对其他人有帮助:)

于 2013-09-24T10:25:33.617 回答