Skip to main content

CRUD Operations using EF Core



CRUD Operations using Entity Framework Core in ASP.NET Core Web API



Overview



Entity Framework Core (EF Core) is an open source, lightweight, cross-platform Object-Relational Mapping (ORM) framework for .NET Core applications. EF Core can be used to perform CRUD (Create, Read, Update and Delete) operations on a database using .NET Core Web APIs. In this guide, we will look at how to use EF Core to perform CRUD operations on a database using ASP.NET Core Web APIs. We will also provide some tips and best practices for working with EF Core.

Creating a Database Context



The first step in using EF Core for CRUD operations is to create a database context. The database context is the entry point to the database, and it is used to query and save data. To create a database context, you need to create a class that derives from Microsoft.EntityFrameworkCore.DbContext. The following is an example of how to create a database context class in C#:


public class DatabaseContext : DbContext
{
public DbSet Customers { get; set; }

public DatabaseContext(DbContextOptions options)
: base(options)
{ }
}


In this example, we are creating a database context class called DatabaseContext and we are setting up a DbSet for the Customer class. The DbSet represents the database table and will be used to perform CRUD operations on the Customer table.

Configuring the Database Context



Once the database context is created, it needs to be configured. The configuration is done in the Startup.cs file in the ConfigureServices method. The following is an example of how to configure the database context in C#:


public void ConfigureServices(IServiceCollection services)
{
services.AddDbContext(options =>
options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection")));
}


In this example, we are configuring the DatabaseContext to use a SQL Server database. The connection string is specified in the appsettings.json file.

Performing CRUD Operations with EF Core



Once the database context is configured, you can use EF Core to perform CRUD operations on the database. The following is an example of how to perform CRUD operations with EF Core in C#:

Creating a Record




public void CreateCustomer(Customer customer)
{
using (var context = new DatabaseContext())
{
context.Customers.Add(customer);
context.SaveChanges();
}
}


Reading a Record




public Customer GetCustomer(int id)
{
using (var context = new DatabaseContext())
{
return context.Customers.Where(c => c.Id == id).FirstOrDefault();
}
}


Updating a Record




public void UpdateCustomer(Customer customer)
{
using (var context = new DatabaseContext())
{
context.Customers.Update(customer);
context.SaveChanges();
}
}


Deleting a Record




public void DeleteCustomer(int id)
{
using (var context = new DatabaseContext())
{
var customer = context.Customers.Where(c => c.Id == id).FirstOrDefault();
context.Customers.Remove(customer);
context.SaveChanges();
}
}


Tips and Best Practices for using EF Core



Here are some tips and best practices for using EF Core for CRUD operations:


  • Always use the using statement when creating a database context. This ensures that the database context is properly disposed and the resources are released properly.

  • Use the Add and Update methods to add and update records in the database. This ensures that the records are added and updated in a consistent way.

  • Use the Remove method to delete records from the database. This ensures that the records are deleted in a consistent way.

  • Be sure to call the SaveChanges method after performing any CRUD operations. This ensures that the changes are saved to the database.



Conclusion



In this guide, we have looked at how to use EF Core to perform CRUD operations on a database using ASP.NET Core Web APIs. We have also provided some tips and best practices for working with EF Core. EF Core is a great way to quickly and easily perform CRUD operations on a database.