[英]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.