[C#] 將Linq查詢結果轉換為字典


Answers

看你的例子,我認為這是你想要的:

var dict = TableObj.ToDictionary(t => t.Key, t=> t.TimeStamp);
Question

我想使用Linq to SQL將一些行添加到數據庫,但是我想在添加行之前進行“自定義檢查”,以了解是否必須添加,替換或忽略包含的行。 我想保持客戶端和數據庫服務器之間的交通盡可能低,並儘量減少查詢次數。

為此,我想獲取驗證所需的盡可能少的信息,並且只在過程開始時獲取一次。

我正在考慮這樣做,但很明顯,它不起作用。 任何人有想法?

Dictionary<int, DateTime> existingItems = 
    (from ObjType ot in TableObj
        select (new KeyValuePair<int, DateTime>(ot.Key, ot.TimeStamp))
    )

最後我想要的是一個Dictionary,而不必從TableObject下載整個ObjectType對象。

我也考慮了下面的代碼,但我試圖找到一個正確的方法:

List<int> keys = (from ObjType ot in TableObj orderby ot.Key select ot.Key).ToList<int>();
List<DateTime> values = (from ObjType ot in TableObj orderby ot.Key select ot.Value).ToList<int>();
Dictionary<int, DateTime> existingItems = new Dictionary<int, DateTime>(keys.Count);
for (int i = 0; i < keys.Count; i++)
{
    existingItems.Add(keys[i], values[i]);
}



使用命名空間

using System.Collections.Specialized;

創建DataContext類的實例

LinqToSqlDataContext dc = new LinqToSqlDataContext();

使用

OrderedDictionary dict = dc.TableName.ToDictionary(d => d.key, d => d.value);

為了檢索值使用命名空間

   using System.Collections;

ICollection keyCollections = dict.Keys;
ICOllection valueCollections = dict.Values;

String[] myKeys = new String[dict.Count];
String[] myValues = new String[dict.Count];

keyCollections.CopyTo(myKeys,0);
valueCollections.CopyTo(myValues,0);

for(int i=0; i<dict.Count; i++)
{
Console.WriteLine("Key: " + myKeys[i] + "Value: " + myValues[i]);
}
Console.ReadKey();



Links