Getting Started with Entity Framework Core

A database stands as a vital component in many applications, serving as the storage and retrieval hub for data.

Traditionally, developers had to convert C# data access code into SQL statements, a process open to errors and time-consuming.

However, with Entity Framework Core, you can delegate the tasks to the framework, allowing you to concentrate on application development.

Let’s explore further.

What is Entity Framework?

Entity Framework Core is a lightweight, open-source, cross-platform object-relational mapper for .NET. It acts as a broker between your .NET application and the database server, facilitating the mapping of .NET objects to database tables and translating C# data access code into SQL statements.

Using Entity Framework Core offers several advantages:

  • No need to learn a new language; utilize C# and LINQ.
  • Tooling to maintain synchronization between C# models and database tables.
  • Real-time tracking of changes to C# entities for effective persistence.
  • Support for multiple database providers.

Now, let’s delve into the process of adding database support to an ASP.NET Core API using Entity Framework Core.

Step 1: Define Your Entity

An entity represents the data to be mapped to a database table. For instance, in a Superheroes application, you might have a SuperHero entity.

public class SuperHero
{
  public int Id { get; set; }
  public string Name { get; set; }
  public string FirstName { get; set; }
  public string LastName { get; set; }
  public string Place { get; set; }
}

Step 2: Integrate DbContext

A DbContext instance manages interactions with the database and facilitates querying and saving of entity instances. It combines the Unit of Work and Repository patterns. Begin by adding the appropriate NuGet package for your database provider.

dotnet add package Microsoft.EntityFrameworkCore.Sqlite

Then create the DbContext class and register it with the service container in Program.cs.

public class DataContext : DbContext
{
  public DataContext(DbContextOptions<DataContext> options) : base(options) { }

  public DbSet<SuperHero> SuperHeroes { get; set; }
}
var connectionString = "Data Source=SuperHero.db";
builder.Services.AddSqlite<DataContext>(connectionString);

Step 3: Generate Database

To translate entities into database tables, you’ll need to create and apply a migration.

Obtain the dotnet-ef tool:

dotnet tool install --global dotnet-ef

Add the required NuGet package:

dotnet add package Microsoft.EntityFrameworkCore.Design

Create the migration and apply it to generate your database:

dotnet ef migrations add InitialCreate //create the migration
dotnet ef database update // apply the migration

Step 4: Create Database Records

Inject your DbContext instance into controller to create and save entity instances into database tables. The SuperHeroes.Add() method instructs Entity Framework Core to track the new game instance, while SaveChangesAsync() executes SQL statements to persist changes to the database.

[Route("api/[controller]")]
[ApiController]
public class SuperHeroController : ControllerBase
{
    private readonly DataContext _context;

    public SuperHeroController(DataContext context)
    {
        _context = context;
    }

    [HttpPost]
    public async Task<ActionResult<List<SuperHero>>> AddHero(SuperHero hero)
    {
        _context.SuperHeroes.Add(hero);
        await _context.SaveChangesAsync();

        return Ok(await _context.SuperHeroes.ToListAsync());
    }
}

Step 5: Query Database Records

Set up an endpoint to retrieve games created in the previous step. Use SuperHeroes.FindAsync() to search for the requested superhero in the DbSet. If not found, Entity Framework Core sends the corresponding SQL query to the database for retrieval.

[HttpGet("{id}")]
public async Task<ActionResult<SuperHero>> Get(int id)
{
    var hero = await _context.SuperHeroes.FindAsync(id);

    if (hero == null)
        return BadRequest("Hero not found.");

    return Ok(hero);
}

With these steps, we’ve built a fully functional database backed ASP.NET Core API using Entity Framework Core. I hope you found this guide helpful.

0
An error has occurred. This application may no longer respond until reloaded. Reload x