Home >Backend Development >C#.Net Tutorial >Entity Framework C#
The following article provides an outline for Entity Framework C#. Entity Framework is an Object Relational Mapping (ORM) that helps to enhance the user’s app productivity by eliminating the redundant job in the application. EF builds the required DB Commands for writing or reading the data in DB and executes them perfectly. Finally, EF executes the query in DB and makes the results into domain objects to work with the application.
Entity Framework is an Object-Source Relational Mapping (ORM) Framework for .Net Applications, which allows the developers to work on relational data by using the domain-specific object without the knowledge of the columns and tables of the database where the data gets stored. Furthermore, it depicts that the Entity Framework minimizes the codes of data accessing that the developers usually write.
Let’s assume the Department and the Employee table tables consider like the table contains the records of several departments and the employees of various departments.
To achieve this, we must build the Department and the Employee classes. Then, to retrieve those data from the database, we need to code ADO.NET. Finally, when the data is retrieved, we have to create objects of Employee and Department to populate them with recovered data.
The above entire thing is tedious, but through Entity Framework, it is easy; those things can be done automatically; we need to provide DB Schema to EF. Let’s see the following steps to create an application using EF.
To create the database schema, make use of the SQL Script to create the database EF_Demo_DB and also to create tables of Employee and Department
Code:
-- to create the Database EF_Demo_DB CREATE DATABASE EF_Demo_DB; GO -- Use EF_Demo_DB database USE EF_Demo_DB; GO -- to Create the table Departments CREATE TABLE Departments ( ID INT PRIMARY KEY IDENTITY(1,1), Name VARCHAR(50), Location VARCHAR(50) ) Go -- to Create the table Employees CREATE TABLE Employees ( ID INT PRIMARY KEY IDENTITY(1,1), Name VARCHAR(50), Email VARCHAR(50), Gender VARCHAR(50), Salary INT, DepartmentId INT FOREIGN KEY REFERENCES Departments(ID) ) Go -- --to Populate the table with few records INSERT INTO Departments VALUES ('HR', 'Bangalore') INSERT INTO Departments VALUES ('Sales', 'Cochin') INSERT INTO Departments VALUES ('IT', 'Chennai') Go --to Populate the table with few records INSERT INTO Employees VALUES ('Philip', '[email protected]', 'Male', 45000, 2) INSERT INTO Employees VALUES ('Mary', '[email protected]', 'Female', 30000, 2) INSERT INTO Employees VALUES ('Valarie', '[email protected]', 'Female', 35000, 3) INSERT INTO Employees VALUES ('John', '[email protected]', 'Male', 80000, 1) INSERT INTO Employees VALUES ('Joseph', 'jojog.com', 'Male', 60000, 1) INSERT INTO Employees VALUES ('Steve', '[email protected]', 'Male', 45000, 3) INSERT INTO Employees VALUES ('Peter', '[email protected]', 'Male', 60000, 1) INSERT INTO Employees VALUES ('Rio', '[email protected]', 'Female', 345000, 3) INSERT INTO Employees VALUES ('Ben', '[email protected]', 'Male', 70000, 1) Go
To Create the Console Application
Once the data is ready, create a new Console Application with the name of EFDemo as shown below:
To Add the ADO.NET Entity Data Model
To create the Console Application add the ADO.NET Entity Data Model and right-click on the project and Add -New Item-Data- ADO.NET Entity Data Model and make the name as EmployeeDataModel as shown below.
Once click on Add button, select the EF Designer from Database and click the Next button as shown below to choose the EF Designer from the database; here, we are using EF Database First Approach.
Once clicking on the Next button, it asks you to choose the data connection wizard as shown; click on the New Connection button.
Once click on that New Connection button, provide the necessary database details and finally, “Test Connection” and click OK.
Select the Data Connection and save the entity connection settings in App. Then, config as shown below, give the name EF_Demo_DBEntities and click the Next button.
Here it asks you to select the Entity Framework 6.x and select the Next button as shown.
Choose the desired tables, change the Model Namespace to “EmployeeModel,” and click on the Finish button as shown.
Clicking on the Finish button generates the EmployeeDataModel.edmx file.
This is the structure of the EDMX file as shown below,
Using the EF, we created the application.
Code:
namespace EFDemo { class Program { static void Main(string[] args) { using (EF_Demo_DBEntities DBEntities = new EF_Demo_DBEntities()) { List<Department> listDepartments = DBEntities.Departments.ToList(); Console.WriteLine(); foreach (Department dept in listDepartments) { Console.WriteLine(" Department = {0}, Location = {1}", dept.Name, dept.Location); foreach (Employee emp in dept.Employees) { Console.WriteLine("\t Name = {0}, Email = {1}, Gender = {2}, salary = {3}", emp.Name, emp.Email, emp.Gender, emp.Salary); } Console.WriteLine(); } Console.ReadKey(); } } } }
Entity Framework Features:
Let’s see the features of Entity Framework:
In this article, we saw the features of EF and how to create the Entity Framework. However, using ADO.NET code is tedious when compared with EF. Also, it is a time-consuming, error-prone process, so Microsoft offers a Framework called Entity Framework to automate the entire DB-related work for our application.
The above is the detailed content of Entity Framework C#. For more information, please follow other related articles on the PHP Chinese website!