我遇到了一些在 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>)”的类型参数。尝试明确指定类型参数。