Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю
На нашем сайте KnigaRead.com Вы можете абсолютно бесплатно читать книгу онлайн Троелсен Эндрю, "Язык программирования C#9 и платформа .NET5" бесплатно, без регистрации.
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(){ // Сортировать по фамилии, затем по имени. var query = Context.Customers .OrderBy(x => x.PersonalInformation.LastName) .ThenBy(x => x.PersonalInformation.FirstName); var qs = query.ToQueryString(); var customers = query.ToList(); // Если есть только один пользователь, то проверять нечего. if (customers.Count <= 1) { return; } for (int x = 0; x < customers.Count - 1; x++) { var pi = customers[x].PersonalInformation; var pi2 = customers[x + 1].PersonalInformation; var compareLastName = string.Compare(pi.LastName, pi2.LastName, StringComparison.CurrentCultureIgnoreCase); Assert.True(compareLastName <= 0); if (compareLastName != 0) continue; var compareFirstName = string.Compare(pi.FirstName, pi2.FirstName, StringComparison.CurrentCultureIgnoreCase); Assert.True(compareFirstName <= 0); }}Предыдущий запрос LINQ транслируется следующим образом:
SELECT [c].[Id], [c].[TimeStamp], [c].[FirstName], [c].[FullName], [c].[LastName]FROM [Dbo].[Customers] AS [c]ORDER BY [c].[LastName], [c].[FirstName]Сортировка записей в обратном порядке
Метод
Reverse()[Fact]public void ShouldSortByFirstNameThenLastNameUsingReverse(){ // Сортировать по фамилии, затем по имени, // и изменить порядок сортировки на противоположный. var query = Context.Customers .OrderBy(x => x.PersonalInformation.LastName) .ThenBy(x => x.PersonalInformation.FirstName) .Reverse(); var qs = query.ToQueryString(); var customers = query.ToList(); // Если есть только один пользователь, то проверять нечего. if (customers.Count <= 1) { return; } for (int x = 0; x < customers.Count - 1; x++) { var pi1 = customers[x].PersonalInformation; var pi2 = customers[x + 1].PersonalInformation; var compareLastName = string.Compare(pi1.LastName, pi2.LastName, StringComparison.CurrentCultureIgnoreCase); Assert.True(compareLastName >= 0); if (compareLastName != 0) continue; var compareFirstName = string.Compare(pi1.FirstName, pi2.FirstName, StringComparison.CurrentCultureIgnoreCase); Assert.True(compareFirstName >= 0); }}Вот во что транслируется предыдущий запрос LINQ:
SELECT [c].[Id], [c].[TimeStamp], [c].[FirstName], [c].[FullName], [c].[LastName] FROM [Dbo].[Customers] AS [c]ORDER BY [c].[LastName] DESC, [c].[FirstName] DESCИзвлечение одиночной записи
Существуют три главных метода для возвращения одиночной записи посредством запроса:
First()/FirstOrDefault()Last()/LastOrDefault()Single()/SingleOrDefault()• Метод
First()• Поведение метода
FirstOrDefault()First()FirstOrDefault()null