Конвертировать результат запроса Linq в словарь - PullRequest
307 голосов
/ 05 июня 2009

Я хочу добавить несколько строк в базу данных, используя Linq to SQL, но я хочу сделать «пользовательскую проверку» перед добавлением строк, чтобы узнать, нужно ли добавлять, заменять или игнорировать поступающие строки. Я хотел бы сохранить как можно меньший трафик между клиентом и сервером БД и минимизировать количество запросов.

Для этого я хочу получить как можно меньше информации, необходимой для проверки, и только один раз в начале процесса.

Я думал сделать что-то подобное, но, очевидно, это не работает. У кого-нибудь есть идея?

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

В конце я хотел бы иметь словарь, без необходимости загружать все объекты ObjectType из TableObject.

Я также рассмотрел следующий код, но пытался найти правильный путь:

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 ]

571 голосов
/ 05 июня 2009

Попробуйте использовать метод ToDictionary , например, так:

var dict = TableObj.ToDictionary( t => t.Key, t => t.TimeStamp );
116 голосов
/ 05 июня 2009

Глядя на ваш пример, я думаю, это то, что вы хотите:

var dict = TableObj.ToDictionary(t => t.Key, t=> t.TimeStamp);
7 голосов
/ 05 июня 2009

Попробуйте следующее

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

Или версия полноценного типа

var existingItems = TableObj.ToDictionary(x => x.Key);
0 голосов
/ 16 октября 2017

Использовать пространство имен

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