gpt4 book ai didi

c# - 将匿名类型转换为数组或数组列表。可以做吗

转载 作者:行者123 更新时间:2023-11-30 13:42:44 27 4
gpt4 key购买 nike

尝试使用 linq 从数据库中检索数据。我想使用匿名类型并转换为 Ilist、Array、ArrayList 或 Collection。数据在接受 Ilist、arraylist 或集合的第三方对象中使用。

我似乎无法让它工作。我收到以下错误消息,“'System.String' 类型不支持序列运算符”

using (var db = new dbDataContext())
{
var query = from e in db.people
select new
{
Count = e.LastName.Count()
};

Array test;
test = query.ToArray();
}

最佳答案

它与将结果转换为数组列表甚至匿名类型无关。这是您的代码的另一个版本,它将失败:

using (var db = new dbDataContext())
{
var query = db.people.Select(x => x.LastName.Count());
foreach (int x in query)
{
Console.WriteLine(x);
}
}

这仍然会以同样的方式失败——因为它是这个位的翻译:

x => x.LastName.Count()

进入导致问题的 SQL。

将其更改为:

x => x.LastName.Length

我想您会发现它有效。请注意,这并不是真正的 C# 问题 - 它只是 LINQ to SQL 的翻译能力。

不过,我建议您不要在这里使用匿名类型——这是没有意义的。也许这不是您的完整代码,但总的来说,如果您发现自己创建了一个只有一个成员的匿名类型,请问问自己它是否真的对您有任何好处。

关于c# - 将匿名类型转换为数组或数组列表。可以做吗,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2180441/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com