将Linq查询结果转换为字典

我想使用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]);
}

尝试使用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);

或者完全成熟的类型推断版本

var existingItems = TableObj.ToDictionary(x => x.Key);
链接地址: http://www.djcxy.com/p/34223.html

上一篇: Convert Linq Query Result to Dictionary

下一篇: Querying DataColumnCollection with LINQ