将Linq查询结果转换为字典

时间:2009-06-05 01:45:25

标签: c# linq linq-to-sql todictionary

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

4 个答案:

答案 0 :(得分:568)

尝试使用the ToDictionary method,如下所示:

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

答案 1 :(得分:116)

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

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

答案 2 :(得分:7)

尝试以下

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

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

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

答案 3 :(得分:0)

使用命名空间

    const imageBuff = Buffer.from(image, 'base64');
     gm(imageBuff)
     .resize(72, 72)
     .strip()
     .write('../curber/newimage.png', function (err) {
    if (!err) console.log('done');

    else
     console.log(err.log, err.stack);
     });

制作using System.Collections.Specialized; Class

的实例
DataContext

使用

LinqToSqlDataContext dc = new LinqToSqlDataContext();

为了检索值,使用命名空间

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