Метод Where
DbSet. Несколько вызовов Where можно плавно объединять в цепочку для динамического построения запроса. Выстроенные в цепочку вызовы Where всегда объединяются с помощью операции "И". Для объединения условий с применением операции "ИЛИ" необходимо использовать один вызов Where.Приведенный ниже тест возвращает заказчиков с фамилией, начинающейся с буквы "W" (нечувствительно к регистру символов):
[Fact]
public void ShouldGetCustomersWithLastNameW
{
IQueryable
.Where(x => x.PersonalInformation.LastName.StartsWith("W"));
var qs = query.ToQueryString;
List
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
[Fact]
public void ShouldGetCustomersWithLastNameWAndFirstNameM
{
IQueryable
.Where(x => x.PersonalInformation.LastName.StartsWith("W"))
.Where(x => x.PersonalInformation.FirstName.StartsWith("M"));
var qs = query.ToQueryString;
List
Assert.Single(customers);
}
Следующий тест возвращает заказчиков с фамилией, начинающейся с буквы "W" (нечувствительно к регистру символов), и именем, начинающимся с буквы "М" (нечувствительно к регистру символов), с применением единственного вызова Where
[Fact]
public void ShouldGetCustomersWithLastNameWAndFirstNameM
{
IQueryable
.Where(x => x.PersonalInformation.LastName.StartsWith("W") &&
x.PersonalInformation.FirstName.StartsWith("M"));
var qs = query.ToQueryString;
List
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
.Where(x => x.PersonalInformation.LastName.StartsWith("W") ||
x.PersonalInformation.LastName.StartsWith("H"));
var qs = query.ToQueryString;
List
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%'))
Бьёрн Страуструп , Ирина Сергеевна Козлова , Бьерн Страуструп , Валерий Федорович Альмухаметов
Программирование, программы, базы данных / Базы данных / Программирование / Учебная и научная литература / Образование и наука / Книги по IT