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

ToList() method using Single() linq query

我对 ToList() 方法有问题,基本上我正在尝试创建一个函数,它将 return 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;

如果需要任何库,请在下方评论或post回答。 这是错误。

'MCM.User' 不包含 'ToList' 的定义并且没有扩展方法 'ToList' 可以找到接受类型 'MCM.User' 的第一个参数(您是否缺少使用指令或程序集参考?) 如果您知道任何答案,请在下面 post。谢谢。

您在 LINQ 语句末尾调用 .Single(),因此该语句 returns 是一个 MCM.User 对象而不是 IEnumerable。删除 .Single().

您正在调用 Single(),这意味着您有 一个 结果。 ToList()IEnumerable<T> 上的扩展方法。

如果你想创建一个只有那个元素的列表,你可以写:

return new List<UsersTabPage> { firstone };

...但似乎更有可能 或者 你应该摆脱 Single() 调用 或者 你应该只需让您的方法 return UsersTabPage.

另一方面,firstone 的类型似乎是 User,而不是 UsersTabPage - 我们对这两种类型之间的关系一无所知,因此您可能也想重新审视这一方面。

你得到了一个对象,你期望哪个列表!

firstone. = ....Single();
firstone.ToList();

这是行不通的...通过在 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();
    }
}

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

您正在返回 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;