首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Linq-to-SQL ToDictionary()

Linq-to-SQL ToDictionary()
EN

Stack Overflow用户
提问于 2008-10-28 22:50:07
回答 4查看 73.1K关注 0票数 83

如何使用Linq将SQL (2008)中的两列正确转换为字典(用于缓存)?

我目前在IQueryable b/c中循环,我不能让ToDictionary方法工作。有什么想法吗?这是可行的:

代码语言:javascript
复制
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);
}

我真正想做的是这样的事情,这似乎行不通:

代码语言:javascript
复制
var dic = (from p in db.Table
             select new {p.Key, p.Value })
            .ToDictionary<string, string>(p => p.Key);

但我得到这个错误:无法从'System.Linq.IQueryable‘转换为'System.Collections.Generic.IEnumerable’

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2008-10-28 22:53:56

代码语言:javascript
复制
var dictionary = db
    .Table
    .Select(p => new { p.Key, p.Value })
    .AsEnumerable()
    .ToDictionary(kvp => kvp.Key, kvp => kvp.Value)
;
票数 126
EN

Stack Overflow用户

发布于 2008-10-28 22:57:50

您仅定义了键,但还需要包括值:

代码语言:javascript
复制
var dic = (from p in db.Table
             select new {p.Key, p.Value })
            .ToDictionary(p => p.Key, p=> p.Value);
票数 16
EN

Stack Overflow用户

发布于 2008-10-28 23:07:38

谢谢你们,你们的回答帮助我解决了这个问题,应该是:

代码语言:javascript
复制
var dic = db
        .Table
        .Select(p => new { p.Key, p.Value })
        .AsEnumerable()
        .ToDictionary(k=> k.Key, v => v.Value);
票数 9
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/245168

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档