Метод Where используется для фильтрации записей из DbSet. Несколько вызовов Where можно плавно объединять в цепочку для динамического построения запроса. Выстроенные в цепочку вызовы Where всегда объединяются с помощью операции "И". Для объединения условий с применением операции "ИЛИ" необходимо использовать один вызов Where.

Приведенный ниже тест возвращает заказчиков с фамилией, начинающейся с буквы "W" (нечувствительно к регистру символов):

[Fact]

public void ShouldGetCustomersWithLastNameW

{

  IQueryable query = Context.Customers

    .Where(x => x.PersonalInformation.LastName.StartsWith("W"));

  var qs = query.ToQueryString;

  List customers = query.ToList;

  Assert.Equal(2, customers.Count);

}

Запрос LINQ транслируется в следующий код SQL:

SELECT [c].[Id], [c].[TimeStamp], [c].[FirstName], [c].[FullName],

       [c].[LastName] FROM [Dbo].[Customers] AS [c]

WHERE [c].[LastName] IS NOT NULL AND ([c].[LastName] LIKE N'W%')

Показанный далее тест возвращает заказчиков с фамилией, начинающейся с буквы "W" (нечувствительно к регистру символов), и именем, начинающимся с буквы "М" (нечувствительно к регистру символов), а также демонстрирует объединение вызовов Where в цепочку в запросе LINQ:

[Fact]

public void ShouldGetCustomersWithLastNameWAndFirstNameM

{

  IQueryable query = Context.Customers

    .Where(x => x.PersonalInformation.LastName.StartsWith("W"))

    .Where(x => x.PersonalInformation.FirstName.StartsWith("M"));

  var qs = query.ToQueryString;

  List customers = query.ToList;

  Assert.Single(customers);

}

Следующий тест возвращает заказчиков с фамилией, начинающейся с буквы "W" (нечувствительно к регистру символов), и именем, начинающимся с буквы "М" (нечувствительно к регистру символов), с применением единственного вызова Where:

[Fact]

public void ShouldGetCustomersWithLastNameWAndFirstNameM

{

  IQueryable query = Context.Customers

    .Where(x => x.PersonalInformation.LastName.StartsWith("W") &&

                x.PersonalInformation.FirstName.StartsWith("M"));

  var qs = query.ToQueryString;

  List customers = query.ToList;

  Assert.Single(customers);

}

Оба запроса транслируются в такой код SQL:

SELECT [c].[Id], [c].[TimeStamp], [c].[FirstName], [c].[FullName],

       [c].[LastName] FROM [Dbo].[Customers] AS [c]

WHERE ([c].[LastName] IS NOT NULL AND ([c].[LastName] LIKE N'W%'))

AND ([c].[FirstName] IS NOT NULL AND ([c].[FirstName] LIKE N'M%'))

Приведенный ниже тест возвращает заказчиков с фамилией, начинающейся с буквы "W" (нечувствительно к регистру символов), или именем, начинающимся с буквы "H" (нечувствительно к регистру символов):

[Fact]

public void ShouldGetCustomersWithLastNameWOrH

{

  IQueryable query = Context.Customers

    .Where(x => x.PersonalInformation.LastName.StartsWith("W") ||

                x.PersonalInformation.LastName.StartsWith("H"));

  var qs = query.ToQueryString;

  List customers = query.ToList;

  Assert.Equal(3, customers.Count);

}

Запрос LINQ транслируется в следующий код SQL:

SELECT [c].[Id], [c].[TimeStamp], [c].[FirstName], [c].[FullName],

       [c].[LastName] FROM [Dbo].[Customers] AS [c]

WHERE ([c].[LastName] IS NOT NULL AND ([c].[LastName] LIKE N'W%'))

OR ([c].[LastName] IS NOT NULL AND ([c].[LastName] LIKE N'H%'))

Перейти на страницу:

Похожие книги