[英]Linq-to-SQL ToDictionary()
如何使用 Linq 将 SQL (2008) 中的两列正确转换为Dictionary
(用于缓存)?
我目前遍历IQueryable
b/c 我无法让ToDictionary
方法工作。 有任何想法吗? 这有效:
var query = from p in db.Table
select p;
Dictionary<string, string> dic = new Dictionary<string, string>();
foreach (var p in query)
{
dic.Add(sub.Key, sub.Value);
}
我真正想做的是这样的事情,这似乎不起作用:
var dic = (from p in db.Table
select new {p.Key, p.Value })
.ToDictionary<string, string>(p => p.Key);
但我得到这个错误:
无法从“System.Linq.IQueryable<AnonymousType#1>”转换为“System.Collections.Generic.IEnumerable”
var dictionary = db
.Table
.Select(p => new { p.Key, p.Value })
.AsEnumerable()
.ToDictionary(kvp => kvp.Key, kvp => kvp.Value)
;
您只定义键,但还需要包含值:
var dic = (from p in db.Table
select new {p.Key, p.Value })
.ToDictionary(p => p.Key, p=> p.Value);
谢谢大家,您的回答帮助我解决了这个问题,应该是:
var dic = db
.Table
.Select(p => new { p.Key, p.Value })
.AsEnumerable()
.ToDictionary(k=> k.Key, v => v.Value);
为什么要为表中的每个项目创建一个匿名对象只是为了转换它?
你可以简单地使用类似的东西: IDictionary<string, string> dic = db.Table.ToDictionary(row => row.Key, row => row.Value);
您可能需要在 Table 和 ToDictionary() 之间包含一个 AsEnumerable() 调用。 我不知道 db.Table 的确切类型。
还要更正第一个示例,您的第二个循环变量在声明和使用时不匹配。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.