books-read.com
books-read.com » Компьютеры и Интернет » Базы данных » Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

Наш ресурс дает возможность бесплатно читать книгу онлайн Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю. Жанр: Базы данных . Сайт books-read.com дает возможность читать полную версию книги без регистрации и sms. Все книги онлайн, не надо качать fb2, epub, txt.
Добавить книгу Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю в приложение ЧИТАТЬ КНИГУ ОФЛАЙН в приложении ios/android
Перейти на страницу:

    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
).

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

Троелсен Эндрю читать все книги автора по порядку

Троелсен Эндрю - на сайте онлайн книг books-read.com Вы можете читать полные версии книг автора в одном месте.


Язык программирования C#9 и платформа .NET5 отзывы

Отзывы читателей о книге Язык программирования C#9 и платформа .NET5, автор: Троелсен Эндрю. Читайте комментарии и мнения людей о произведении.


Уважаемые читатели и просто посетители нашей библиотеки! Просим Вас придерживаться определенных правил при комментировании литературных произведений.

  • 1. Просьба отказаться от дискриминационных высказываний. Мы защищаем право наших читателей свободно выражать свою точку зрения. Вместе с тем мы не терпим агрессии. На сайте запрещено оставлять комментарий, который содержит унизительные высказывания или призывы к насилию по отношению к отдельным лицам или группам людей на основании их расы, этнического происхождения, вероисповедания, недееспособности, пола, возраста, статуса ветерана, касты или сексуальной ориентации.
  • 2. Просьба отказаться от оскорблений, угроз и запугиваний.
  • 3. Просьба отказаться от нецензурной лексики.
  • 4. Просьба вести себя максимально корректно как по отношению к авторам, так и по отношению к другим читателям и их комментариям.

Надеемся на Ваше понимание и благоразумие. С уважением, администратор books-read.com


Прокомментировать
Подтвердите что вы не робот:*