Skip to main content

Performing Basic CRUD Operations with Models

Performing Basic CRUD Operations with Models in Entity Framework

Introduction

Entity Framework is an object-relational mapper (ORM) that enables developers to work with a database using .NET objects. It simplifies the database access process by providing an easy-to-use API for performing CRUD (Create, Read, Update, and Delete) operations. In this guide, we will discuss the basics of performing CRUD operations with models in Entity Framework.

Getting Started

To get started, we first need to create a model class that represents the database table that we want to work with. For example, if we want to work with a table called “Customers”, we would create a class called “Customer” that has properties that match the columns in the table.
public class Customer
{
    public int Id { get; set; }
    public string Name { get; set; }
    public string Email { get; set; }
    public string Phone { get; set; }
}
Once the model class is created, we can now create a data context class that will enable us to connect to the database and perform operations. The data context class will also contain methods for performing CRUD operations.
public class CustomerDataContext : DbContext
{
    public DbSet Customers { get; set; }

    protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
    {
        optionsBuilder.UseSqlServer("Server=server;Database=database;User Id=user;Password=password;");
    }

    public void AddCustomer(Customer customer)
    {
        this.Customers.Add(customer);
        this.SaveChanges();
    }

    public Customer GetCustomerById(int id)
    {
        return this.Customers.Find(id);
    }

    public void UpdateCustomer(Customer customer)
    {
        this.Customers.Update(customer);
        this.SaveChanges();
    }

    public void DeleteCustomer(Customer customer)
    {
        this.Customers.Remove(customer);
        this.SaveChanges();
    }
}

Create Operation

The create (or insert) operation is used to add a new record to the database. To perform this operation, we need to use the Add method of the DbSet class. The Add method takes an object as a parameter, which should be an instance of the model class that we created earlier. For example, if we wanted to add a new customer to the database, we would create an instance of the Customer class and then pass it to the Add method.
using (var db = new CustomerDataContext())
{
    var customer = new Customer
    {
        Name = "John Doe",
        Email = "[email protected]",
        Phone = "123-456-7890"
    };

    db.AddCustomer(customer);
}

Read Operation

The read (or select) operation is used to retrieve records from the database. To perform this operation, we need to use the Find method of the DbSet class. The Find method takes an id as a parameter, which should be the primary key of the record that we want to retrieve. For example, if we wanted to retrieve a customer from the database, we would pass the id of the customer to the Find method.
using (var db = new CustomerDataContext())
{
    var customer = db.GetCustomerById(1);
}

Update Operation

The update (or modify) operation is used to update an existing record in the database. To perform this operation, we need to use the Update method of the DbSet class. The Update method takes an object as a parameter, which should be an instance of the model class that we created earlier. For example, if we wanted to update a customer in the database, we would create an instance of the Customer class and then pass it to the Update method.
using (var db = new CustomerDataContext())
{
    var customer = db.GetCustomerById(1);
    customer.Name = "Jane Doe";
    db.UpdateCustomer(customer);
}

Delete Operation

The delete (or remove) operation is used to delete an existing record from the database. To perform this operation, we need to use the Remove method of the DbSet class. The Remove method takes an object as a parameter, which should be an instance of the model class that we created earlier. For example, if we wanted to delete a customer from the database, we would create an instance of the Customer class and then pass it to the Remove method.
using (var db = new CustomerDataContext())
{
    var customer = db.GetCustomerById(1);
    db.DeleteCustomer(customer);
}

Conclusion

In this guide, we discussed the basics of performing CRUD operations with models in Entity Framework. We saw how to create a model class that represents a database table, create a data context class, and then use the Add, Find, Update, and Remove methods of the DbSet class to perform CRUD operations.

Tips

  • Always use the primary key when performing read and delete operations.
  • Be sure to call the SaveChanges method after performing an add, update, or delete operation.
  • Ensure that the model class properties match the database table columns.