Lia*_*ith 3 c# linq linq-to-sql
我仍然是Linq-To-SQL的新手,当我尝试使用join运算符(相当于SQL内部联接)时,我遇到了问题.
获取用户的所有首选项:
return (from u in DataContext.UserPreference
join p in DataContext.Preference on p.Id equals u.PreferenceId
where u.UserId = userId
select p).ToList();
Run Code Online (Sandbox Code Playgroud)
Visual Studio告诉我,查询中的"join"运算符是Enumerable类和Queryable类之间的"模糊调用".
我有什么想法可以解决这个问题?
您的联接表达方式错误 - 您应首先使用u,然后p:
return (from u in DataContext.UserPreference
join p in DataContext.Preference on u.PreferenceId equals p.Id
where u.UserId == userId
select p).ToList();
Run Code Online (Sandbox Code Playgroud)
基本上,您使用连接左侧的第一个范围变量,右侧的第二个变量.
通常编译器会发现这种错误,这恰恰表明了什么是错误的.我不知道为什么在这种情况下没有,但无论哪种方式都应该是修复.
| 归档时间: |
|
| 查看次数: |
1843 次 |
| 最近记录: |