Я хочу добавить некоторые строки в базу данных с использованием Linq to SQL, но я хочу сделать "пользовательскую проверку" перед добавлением строк, чтобы знать, нужно ли добавлять, заменять или игнорировать входящие строки. Я хотел бы сохранить трафик между клиентом и сервером БД как можно ниже и минимизировать количество запросов.
Чтобы сделать это, я хочу получить как можно меньше информации, необходимой для проверки, и только один раз в начале процесса.
Я думал делать что-то подобное, но, очевидно, это не работает. У кого-нибудь есть идея?
Dictionary<int, DateTime> existingItems =
(from ObjType ot in TableObj
select (new KeyValuePair<int, DateTime>(ot.Key, ot.TimeStamp))
)
То, что я хотел бы иметь в конце, будет Dictionary, без необходимости загружать целые объекты 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]);
}