Book Image

C# 8.0 and .NET Core 3.0 – Modern Cross-Platform Development - Fourth Edition

By : Mark J. Price
Book Image

C# 8.0 and .NET Core 3.0 – Modern Cross-Platform Development - Fourth Edition

By: Mark J. Price

Overview of this book

In C# 8.0 and .NET Core 3.0 – Modern Cross-Platform Development, Fourth Edition, expert teacher Mark J. Price gives you everything you need to start programming C# applications. This latest edition uses the popular Visual Studio Code editor to work across all major operating systems. It is fully updated and expanded with new chapters on Content Management Systems (CMS) and machine learning with ML.NET. The book covers all the topics you need. Part 1 teaches the fundamentals of C#, including object-oriented programming, and new C# 8.0 features such as nullable reference types, simplified switch pattern matching, and default interface methods. Part 2 covers the .NET Standard APIs, such as managing and querying data, monitoring and improving performance, working with the filesystem, async streams, serialization, and encryption. Part 3 provides examples of cross-platform applications you can build and deploy, such as web apps using ASP.NET Core or mobile apps using Xamarin.Forms. The book introduces three technologies for building Windows desktop applications including Windows Forms, Windows Presentation Foundation (WPF), and Universal Windows Platform (UWP) apps, as well as web applications, web services, and mobile apps.
Table of Contents (21 chapters)

Loading patterns with EF Core

There are three loading patterns that are commonly used with EF: lazy loading, eager loading, and explicit loading. In this section, we're going to introduce each of them.

Eager loading entities

In the QueryingCategories method, the code currently uses the Categories property to loop through each category, outputting the category name and the number of products in that category. This works because when we wrote the query, we used the Include method to use eager loading (also known as early loading) for the related products.

  1. Modify the query to comment out the Include method call, as shown in the following code:
    IQueryable<Category> cats = 
      db.Categories; //.Include(c => c.Products);
  2. In Main, comment all methods except QueryingCategories, as shown in the following code:
    static void Main(string[] args)
    {
      QueryingCategories();
      // QueryingProducts();
      // QueryingWithLike();
    }
  1. Run the console application and...