Я пытаюсь заставить Linq закрепить внутреннее соединение между двумя таблицами. Я приведу пример.
CREATE TABLE [dbo].[People] (
[PersonId] [int] NOT NULL,
[Name] [nvarchar](MAX) NOT NULL,
[UpdatedDate] [smalldatetime] NOT NULL
... Other fields ...
)
CREATE TABLE [dbo].[CompanyPositions] (
[CompanyPositionId] [int] NOT NULL,
[CompanyId] [int] NOT NULL,
[PersonId] [int] NOT NULL,
... Other fields ...
)
Теперь я работаю с необычной базой данных, так как есть причина, по которой я не могу контролировать людей, которых нет в таблице People, но есть запись в CompanyPositions. Я хочу отфильтровать CompanyPosition с отсутствующими людьми, соединяя таблицы.
return (from pos in CompanyPositions
join p in People on pos.PersonId equals p.PersonId
select pos).ToList();
Linq считает это объединение избыточным и удаляет его из создаваемого SQL.
SELECT
[Extent1].[CompanyPositionId] AS [CompanyPositionId],
[Extent1].[CompanyId] AS [CompanyId],
....
FROM [dbo].[CompanyPositions] AS [Extent1]
Однако это не избыточно в моем случае. Я могу это исправить
// The min date check will always be true, here to force linq to perform the inner join
var minDate = DateTimeExtensions.SqlMinSmallDate;
return (from pos in CompanyPositions
join p in People on pos.PersonId equals p.PersonId
where p.UpdatedDate >= minDate
select pos).ToList();
Однако теперь это создает ненужное предложение where в моем SQL. Как чистейший я хотел бы удалить это. Любая идея или текущий дизайн базы данных связывают мои руки?