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
Перейти на страницу:

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 =&gt; x.PersonalInformation.LastName.StartsWith(&quot;W&quot;) ||</b>

<b>                x.PersonalInformation.LastName.StartsWith(&quot;H&quot;));</b>

  var qs = query.ToQueryString();

  List&lt;Customer&gt; 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&lt;Customer&gt; query = Context.Customers

<b>    .Where(x =&gt; EF.Functions.Like(x.PersonalInformation.LastName, &quot;W%&quot;) ||</b>

<b>                EF.Functions.Like(x.PersonalInformation.LastName, &quot;H%&quot;));</b>

  var qs = query.ToQueryString();

  List&lt;Customer&gt; 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&lt;Car&gt; query =

    Context.Cars.IgnoreQueryFilters().Where(x =&gt; 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(&quot;Black&quot;,2)]

[InlineData(&quot;Rust&quot;,1)]

[InlineData(&quot;Yellow&quot;,1)]

[InlineData(&quot;Green&quot;,0)]

[InlineData(&quot;Pink&quot;,1)]

[InlineData(&quot;Brown&quot;,0)]

public void ShouldGetAllViewModelsByColor(string color, int expectedCount)

{

    var query = _repo.GetOrdersViewModel().Where(x=&gt;x.Color == color);

    var qs = query.ToQueryString();

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

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

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


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

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


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

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

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


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