Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю
На нашем сайте KnigaRead.com Вы можете абсолютно бесплатно читать книгу онлайн Троелсен Эндрю, "Язык программирования C#9 и платформа .NET5" бесплатно, без регистрации.
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<Customer> query = Context.Customers<b> .Where(x => x.PersonalInformation.LastName.StartsWith("W") ||</b><b> x.PersonalInformation.LastName.StartsWith("H"));</b> var qs = query.ToQueryString(); List<Customer> 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%'))Показанный далее тест возвращает заказчиков с фамилией, начинающейся с буквы "W" (нечувствительно к регистру символов), или именем, начинающимся с буквы "Н" (нечувствительно к регистру символов), и демонстрирует использование метода
EF.Functions.Like()%[Fact]public void ShouldGetCustomersWithLastNameWOrH(){ IQueryable<Customer> query = Context.Customers<b> .Where(x => EF.Functions.Like(x.PersonalInformation.LastName, "W%") ||</b><b> EF.Functions.Like(x.PersonalInformation.LastName, "H%"));</b> var qs = query.ToQueryString(); List<Customer> customers = query.ToList(); Assert.Equal(3, customers.Count);}Запрос LINQ транслируется в следующий код SQL (обратите внимание, что проверка на
nullSELECT [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]InventoryMakeIdIgnoreQueryFilters()[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<Car> query = Context.Cars.IgnoreQueryFilters().Where(x => x.MakeId == makeId); var qs = query.ToQueryString(); var cars = query.ToList(); Assert.Equal(expectedCount, cars.Count);}Каждая строка
[InlineData][Theory]MakeIdDECLARE @__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]CustomerOrderViewModelOrderTests.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();