使用Single()linq查询的ToList()方法

时间:2015-04-21 19:26:34

标签: c# sql-server wpf linq linq-to-sql

我有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;的第一个参数。可以找到(你错过了使用指令或程序集引用吗?) 如果您知道任何答案,请在下面发布。谢谢。

5 个答案:

答案 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();
    }
}