Показанный далее тест возвращает заказчиков с фамилией, начинающейся с буквы "W" (нечувствительно к регистру символов),
EF.Functions.Like. Обратите внимание, что включать групповой символ (%) вы должны самостоятельно.[Fact]
public void ShouldGetCustomersWithLastNameWOrH
{
IQueryable
.Where(x => EF.Functions.Like(x.PersonalInformation.LastName, "W%") ||
EF.Functions.Like(x.PersonalInformation.LastName, "H%"));
var qs = query.ToQueryString;
List
Assert.Equal(3, customers.Count);
}
Запрос LINQ транслируется в следующий код SQL (обратите внимание, что проверка на null
SELECT [c].[Id], [c].[TimeStamp], [c].[FirstName], [c].[FullName],
[c].[LastName]
FROM [Dbo].[Customers] AS [c]WHERE ([c].[LastName] LIKE N'W%') OR ([c].[LastName] LIKE N'H%')
В приведенном ниже тесте из класса CarTests.cs
[Theory] для проверки количества записей Car в таблице Inventory на основе MakeId (метод IgnoreQueryFilters рассматривался в разделе "Глобальные фильтры запросов" главы 22):[Theory]
[InlineData(1, 2)]
[InlineData(2, 1)]
[InlineData(3, 1)]
[InlineData(4, 2)]
[InlineData(5, 3)]
[InlineData(6, 1)]
public void ShouldGetTheCarsByMake(int makeId, int expectedCount)
{
IQueryable
Context.Cars.IgnoreQueryFilters.Where(x => x.MakeId == makeId);
var qs = query.ToQueryString;
var cars = query.ToList;
Assert.Equal(expectedCount, cars.Count);
}
Каждая строка [InlineData]
[Theory] будет значение MakeId):DECLARE @__makeId_0 int = 1;
SELECT [i].[Id], [i].[Color], [i].[IsDrivable], [i].[MakeId], [i].[PetName],
[i].[TimeStamp]
FROM [dbo].[Inventory] AS [i]WHERE [i].[MakeId] = @__makeId_0
Следующий тест [Theory]
CustomerOrderViewModel (поместите тест в файл класса OrderTests.cs):[Theory]
[InlineData("Black",2)]
[InlineData("Rust",1)]
[InlineData("Yellow",1)]
[InlineData("Green",0)]
[InlineData("Pink",1)]
[InlineData("Brown",0)]
public void ShouldGetAllViewModelsByColor(string color, int expectedCount)
{
var query = _repo.GetOrdersViewModel.Where(x=>x.Color == color);
var qs = query.ToQueryString;
var orders = query.ToList;
Assert.Equal(expectedCount,orders.Count);
}
Для первого теста [InlineData]
DECLARE @__color_0 nvarchar(4000) = N'Black';
SELECT [c].[Color], [c].[FirstName], [c].[IsDrivable], [c].[LastName],
[c].[Make], [c].
[PetName] FROM [dbo].[CustomerOrderView] AS [c]WHERE [c].[Color] = @__color_0
Сортировка записей
Методы OrderBy
OrderByDescending устанавливают для запроса сортировку (сортировки) по возрастанию и по убыванию. Если требуются дальнейшие сортировки, тогда используйте методы ThenBy и ThenByDescending. Сортировка демонстрируется в тесте ниже:[Fact]
public void ShouldSortByLastNameThenFirstName
{
Бьёрн Страуструп , Ирина Сергеевна Козлова , Бьерн Страуструп , Валерий Федорович Альмухаметов
Программирование, программы, базы данных / Базы данных / Программирование / Учебная и научная литература / Образование и наука / Книги по IT