将Linq查询结果转换为字典

我想使用Linq to SQL将一些行添加到数据库,但是我想在添加行之前进行“自定义检查”,以了解是否必须添加,replace或忽略包含的行。 我想保持客户端和数据库服务器之间的交通尽可能低,并尽量减less查询次数。

要做到这一点,我想获取validation所需的尽可能less的信息,并且只在过程的开始阶段进行一次。

我正在考虑做这样的事情,但很明显,这是行不通的。 任何人有一个想法?

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

我最后想要的是一个Dictionary,而不必从TableObject下载整个ObjectType对象。

我也考虑了下面的代码,但我试图find一个正确的方法:

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

尝试使用ToDictionary方法如下所示:

 var dict = TableObj.Select( t => new { t.Key, t.TimeStamp } ) .ToDictionary( t => t.Key, t => t.TimeStamp ); 

看你的例子,我想这是你想要的:

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

尝试以下

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

或完全成熟的types推断版本

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

使用命名空间

 using System.Collections.Specialized; 

创buildDataContext类的实例

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