Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю
{ var qs = Context.Customers.ToQueryString(); var customers = Context.Customers.ToList(); Assert.Equal(5, customers.Count);}Выделенный полужирным оператор транслируется в следующий код SQL:
SELECT [c].[Id], [c].[TimeStamp], [c].[FirstName], [c].[FullName], [c].[LastName] FROM [Dbo].[Customers] AS [c]Тот же самый процесс применяется для сущностей без ключей, подобных модели представления
CustomerOrderViewModelCustomerOrderViewmodelBuilder.Entity<CustomerOrderViewModel>().HasNoKey() .ToView("CustomerOrderView", "dbo");Экземпляр
DbSet<T>DbSet<T>OrderTest.cspublic void ShouldGetAllViewModels(){ var qs = Context.Orders.ToQueryString(); var orders = Context.Orders.ToList(); Assert.NotEmpty(orders); Assert.Equal(5,orders.Count);}Выделенный полужирным оператор транслируется в следующий код SQL:
SELECT [c].[Color], [c].[FirstName], [c].[IsDrivable], [c].[LastName], [c].[Make], [c].[PetName] FROM [dbo].[CustomerOrderView] AS [c]Фильтрация записей
Метод
Where()DbSet<T>Where()Where()Where()Приведенный ниже тест возвращает заказчиков с фамилией, начинающейся с буквы "W" (нечувствительно к регистру символов):
[Fact]public void ShouldGetCustomersWithLastNameW(){ IQueryable<Customer> query = Context.Customers<b> .Where(x => x.PersonalInformation.LastName.StartsWith("W"));</b> var qs = query.ToQueryString(); List<Customer> customers = query.ToList(); Assert.Equal(2, 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%')Показанный далее тест возвращает заказчиков с фамилией, начинающейся с буквы "W" (нечувствительно к регистру символов), и именем, начинающимся с буквы "М" (нечувствительно к регистру символов), а также демонстрирует объединение вызовов
Where()[Fact]public void ShouldGetCustomersWithLastNameWAndFirstNameM(){ IQueryable<Customer> query = Context.Customers<b> .Where(x => x.PersonalInformation.LastName.StartsWith("W"))</b><b> .Where(x => x.PersonalInformation.FirstName.StartsWith("M"));</b> var qs = query.ToQueryString(); List<Customer> customers = query.ToList(); Assert.Single(customers);}Следующий тест возвращает заказчиков с фамилией, начинающейся с буквы "W" (нечувствительно к регистру символов), и именем, начинающимся с буквы "М" (нечувствительно к регистру символов), с применением единственного вызова
Where()[Fact]public void ShouldGetCustomersWithLastNameWAndFirstNameM(){ IQueryable<Customer> query = Context.Customers<b> .Where(x => x.PersonalInformation.LastName.StartsWith("W") &&</b><b> x.PersonalInformation.FirstName.StartsWith("M"));</b> var qs = query.ToQueryString(); List<Customer> customers = query.ToList(); Assert.Single(customers);}Оба запроса транслируются в такой код SQL:
SELECT [c].[Id], [c].[TimeStamp], [c].[FirstName], [c].[FullName], [c].[LastName] FROM [Dbo].[Customers] AS [c]