Я хочу добавить несколько строк в базу данных, используя 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]);
}
var servers = list.Select( s => new { s.ProjectName, Url = "tcp://" + s.BuildMachineName + ":" + s.PortNumber + "/CruiseManager.rem" } ).ToDictionary( s => s.ProjectName, s.Url );
это создаст словарь, основанный на имени проекта пар имя проекта / URL..Select( t => new { t.Key, t.TimeStamp } )
нужно выражение?.Select
заставляет сгенерированный SQL выбирать только Key и TimeStamp, а не выбирать каждый столбец.Select
если вы делаете Linq to Object (вместо Linq to SQL)Глядя на ваш пример, я думаю, что это то, что вы хотите:
источник
Попробуйте следующее
Или полноценная версия с выводом типа
источник
Использовать пространство имен
Сделайте экземпляр
DataContext
классаиспользование
Для получения значений используйте пространство имен
источник