我有ToList()方法的问题,基本上我试图创建一个函数,它将返回一个var linq查询转换为一个列表,这里是函数。
List<UsersTabPage> GetFirstOne()
{
using (MCMDataContext db = new MCMDataContext())
{
MCM.User user = new MCM.User();
var firstone = (from oneUser in db.Users
where oneUser.ID == user.ID
select oneUser).Single();
return firstone.ToList();
}
}
以下是我目前在该应用程序中使用的库。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
using Microsoft.Win32;
using MahApps.Metro.Controls.Dialogs;
using System.IO;
using System.Data;
如果需要任何图书馆,请在下方发表评论或发布答案。 这是错误。
&#39; MCM.User&#39;不包含&#39; ToList&#39;的定义没有扩展方法&#39; ToList&#39;接受类型&#39; MCM.User&#39;的第一个参数。可以找到(你错过了使用指令或程序集引用吗?) 如果您知道任何答案,请在下面发布。谢谢。
答案 0 :(得分:10)
您正在调用Single()
,这意味着您已经一个结果。 ToList()
是IEnumerable<T>
上的扩展方法。
如果您想创建仅包含该元素的列表,可以写:
return new List<UsersTabPage> { firstone };
...但似乎更有可能 你应该摆脱Single()
调用或你应该让你的方法返回{{1 }}
另一方面,看起来UsersTabPage
的类型是firstone
,而不是User
- 我们对这两种类型之间的关系一无所知,所以你可能也想重新审视那个方面。
答案 1 :(得分:3)
您在LINQ语句的末尾调用.Single()
,以便该语句返回MCM.User
个对象而不是IEnumerable
。删除.Single()
。
答案 2 :(得分:2)
您正在返回UsersTabPage
类型的单个对象,因此您无法调用ToList()
,因为可以在集合上调用ToList()
,而不能在不是集合的单个实例上调用它。
您可以使用Take()
以下方式:
var firstone = (from oneUser in db.Users
where oneUser.ID == user.ID
select oneUser).Take(1).ToList();
return firstone;
使用lambda语法或更简单:
var firstone = db.Users.Where(oneUser => oneUser.ID == user.ID)
.Take(1).ToList();
return firstone;
答案 3 :(得分:0)
你有单个对象,你期望哪个列表!
firstone. = ....Single();
firstone.ToList();
答案 4 :(得分:0)
它无法正常工作......通过在LINQ查询中选择.Single()
,您只获得一个结果,因此无法将一个元素转换为列表。
如果您想转换为列表,请移除.Single()
。
当我向人们提及var
应该谨慎使用时,这正是我的观点:通过适当的显式类型定义可以避免整个问题。
List<UsersTabPage> GetFirstOne()
{
using (MCMDataContext db = new MCMDataContext())
{
MCM.User user = new MCM.User();
var firstone = (from oneUser in db.Users
where oneUser.ID == user.ID
select oneUser);
return firstone.ToList();
}
}
OR
List<UsersTabPage> GetFirstOne()
{
using (MCMDataContext db = new MCMDataContext())
{
MCM.User user = new MCM.User();
return (from oneUser in db.Users
where oneUser.ID == user.ID
select oneUser).ToList();
}
}