將Linq查詢結果轉換爲字典

我想使用Linq to SQL向數據庫添加一些行,但我想在添加行以前進行「自定義檢查」,以瞭解是否必須添加,替換或忽略進行的行。 我想盡量下降客戶端和數據庫服務器之間的流量,並儘可能減小查詢次數。 數據庫

爲此,我但願獲取驗證所需的信息,而且只須要在流程開始時獲取一次。 服務器

我在考慮作這樣的事情,但很明顯,它不起做用。 有人有想法嗎? spa

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

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

我還考慮瞭如下代碼,但我試圖找到一個正確的方法: 對象

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]);
}

#1樓

使用命名空間 ci

using System.Collections.Specialized;

製做DataContext類的實例 get

LinqToSqlDataContext dc = new LinqToSqlDataContext();

使用 it

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

爲了檢索值,使用命名空間 io

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();

#2樓

請嘗試如下方法 List

Dictionary<int, DateTime> existingItems = 
    (from ObjType ot in TableObj).ToDictionary(x => x.Key);

或徹底成熟的類型推斷版本

var existingItems = TableObj.ToDictionary(x => x.Key);

#3樓

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

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

#4樓

嘗試使用ToDictionary方法,以下所示:

var dict = TableObj.ToDictionary( t => t.Key, t => t.TimeStamp );
相關文章
相關標籤/搜索