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

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

Книгу Язык программирования C#9 и платформа .NET5 - Эндрю Троелсен читаем онлайн бесплатно полную версию! Чтобы начать читать не надо регистрации. Напомним, что читать онлайн вы можете не только на компьютере, но и на андроид (Android), iPhone и iPad. Приятного чтения!

178 0 18:04, 26-08-2023
Язык программирования C#9 и платформа .NET5 - Эндрю Троелсен
26 август 2023

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

В 10-м издании книги описаны новейшие возможности языка C# 9 и .NET 5 вместе с подробным "закулисным" обсуждением, призванным расширить навыки критического мышления разработчиков, когда речь идет об их ремесле. Книга охватывает ASP.NET Core, Entity Framework Core и многое другое наряду с последними обновлениями унифицированной платформы .NET, начиная с улучшений показателей производительности настольных приложений Windows в .NET 5 и обновления инструментария XAML и заканчивая расширенным рассмотрением файлов данных и способов обработки данных. Все примеры кода были переписаны с учетом возможностей последнего выпуска C# 9.

    1 ... 295 296 297 298 299 300 301 302 303 ... 407
    Перейти на страницу:
    символов), или именем, начинающимся с буквы "H" (нечувствительно к регистру символов):

    [Fact]

    public void ShouldGetCustomersWithLastNameWOrH()

    {

      IQueryable<Customer> query = Context.Customers

        .Where(x => x.PersonalInformation.LastName.StartsWith("W") ||

                    x.PersonalInformation.LastName.StartsWith("H"));

      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

        .Where(x => EF.Functions.Like(x.PersonalInformation.LastName, "W%") ||

                    EF.Functions.Like(x.PersonalInformation.LastName, "H%"));

      var qs = query.ToQueryString();

      List<Customer> customers = query.ToList();

      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<Car> query =

        Context.Cars.IgnoreQueryFilters().Where(x => x.MakeId == makeId);

      var qs = query.ToQueryString();

      var cars = query.ToList();

      Assert.Equal(expectedCount, cars.Count);

    }

    Каждая строка [InlineData] становится уникальным тестом в средстве запуска тестов. В этом примере обрабатываются шесть тестов и в отношении базы данных выполняются шесть запросов. Вот как выглядит код SQL для одного из тестов (единственным отличием в запросах для других тестов в [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()

    {

      // Сортировать по фамилии, затем по имени.

      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(), но

    1 ... 295 296 297 298 299 300 301 302 303 ... 407
    Перейти на страницу:
    1. Жалоба
    Отзывы - 0

    Прочитали книгу? Предлагаем вам поделится своим отзывом от прочитанного(прослушанного)! Ваш отзыв будет полезен читателям, которые еще только собираются познакомиться с произведением.


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

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

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


    Установить VPN и читай слушай бесплатно

    Новые отзывы

    1. Людмила Хофман Людмила Хофман10 июнь 22:13 У меня перевернулся мир после прочтения ваших книг! Так приятно и чисто на душе, ведь по сути неважно кто с кем , а только любовь... Долгая игра - Рейчел Рид
    2. Анна Анна08 июнь 11:28 Спасибо за новую историю жизни и любви на сайте,прочитала с удовольствием .... Давай поженимся - Юлия Резник
    3. Елена Елена08 июнь 11:13 Прочла несколько романов этого, без сомнения, талантливого автора. Впечатление прекрасное, но хотелось бы когда-нибудь прочесть... Предатель. Ты врал мне годами - Арина Арская
    Все комметарии
    Новинки бесплатной онлайн библиотеки