Я хочу додати кілька рядків до бази даних за допомогою Linq до 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]);
}