Выражение запроса Соединение контекста с примитивным списком

У меня есть следующее -

IEnumerable<int> vendorIds;

var vendors = (from v in _context.Vendors
               where vendorIds.Any(v.VendorId));

но то, что я чувствую, это будет не так эффективно, как присоединение к продавцам со списком, и хотелось бы что-то вроде этого

var vendors = (from v in _context.Vendors
               join vi in vendorIds on v.VendorId == vi);

Однако этот синтаксис недействителен. Я не совсем уверен, как сделать это сравнение. Некоторая помощь будет оценена

вместо == используйте equals

Ehsan Sajjad 17.05.2022 16:05
Формы c голосовым вводом в React с помощью Speechly
Формы c голосовым вводом в React с помощью Speechly
Пытались ли вы когда-нибудь заполнить веб-форму в области электронной коммерции, которая требует много кликов и выбора? Вас попросят заполнить дату,...
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Будучи разработчиком веб-приложений, легко впасть в заблуждение, считая, что приложение без JavaScript не имеет права на жизнь. Нам становится удобно...
Flatpickr: простой модуль календаря для вашего приложения на React
Flatpickr: простой модуль календаря для вашего приложения на React
Если вы ищете пакет для быстрой интеграции календаря с выбором даты в ваше приложения, то библиотека Flatpickr отлично справится с этой задачей....
В чем разница между Promise и Observable?
В чем разница между Promise и Observable?
Разберитесь в этом вопросе, и вы значительно повысите уровень своей компетенции.
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Клиент для URL-адресов, cURL, позволяет взаимодействовать с множеством различных серверов по множеству различных протоколов с синтаксисом URL.
Четыре эффективных способа центрирования блочных элементов в CSS
Четыре эффективных способа центрирования блочных элементов в CSS
У каждого из нас бывали случаи, когда нам нужно отцентрировать блочный элемент, но мы не знаем, как это сделать. Даже если мы реализуем какой-то...
0
1
22
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Ваш первый способ не должен влиять на производительность. Для подтверждения вы можете сравнить оба способа.

В синтаксисе запроса Linq нам нужно использовать equals для соединения, например:

var vendors = (from v in _context.Vendors
               join vi in vendorIds on v.VendorId equals vi
               select v);

Но это можно сделать более простым способом, как показано ниже:

var vendors = _context.Vendors.Where(v => vendorIds.Any(vid => vid == v.VendorId));

да, последний «проще», однако это сложность n ^ 2

Adjit 17.05.2022 16:25

Другие вопросы по теме