Mã hóa và quản lý để truy cập dữ liệu bằng mã ADO .Net là công việc tẻ nhạt và buồn tẻ. Do đó, Microsoft cung cấp một khung công tác O / RM được gọi là “Entity Framework” để tự động hóa các hoạt động liên quan đến cơ sở dữ liệu nhằm giúp bạn xây dựng ứng dụng dễ dàng hơn. Vậy Entity Framework là gì? Bạn hãy cùng giaidap247 tìm hiểu Entity Framework là gì nhé?
Entity Framework là gì?
Entity Framework được sinh ra để hỗ trợ tương tác giữa các ứng dụng dựa trên .NET và cơ sở dữ liệu quan hệ. Ngoài ra, Entity Framework là một công cụ giúp ánh xạ các đối tượng trong ứng dụng và phần mềm với các bảng trong cơ sở dữ liệu quan hệ.
Hay một định nghĩa khác về Entity Framework:
Entity Framework là một khung ORM (Object Relational Mapper) mã nguồn mở dành cho các ứng dụng .NET do Microsoft cung cấp. là một phần của .NET Framework. là một khung ORM mã nguồn mở.
Lưu ý: ORM là một công cụ tự động tạo các đối tượng trong ứng dụng từ các bảng, dạng xem và các thủ tục được lưu trữ của cơ sở dữ liệu quan hệ.
Emntity Framework giúp các nhà phát triển web tương tác với dữ liệu quan hệ theo hướng đối tượng với ít mã hơn các ứng dụng truyền thống. Lợi ích lớn nhất của nó là giúp các lập trình viên giảm số lượng mã cần thiết để truy cập và tương tác với cơ sở dữ liệu.
Hiện tại, Entity framework là một khung phát triển ứng dụng web mạnh mẽ được hỗ trợ bởi một cộng đồng lớn.
Lịch sử ra đời
Entity Framework được phát hành vào năm 2008. Nhờ sự ra đời của nó, việc truy vấn cơ sở dữ liệu quan hệ đã trở nên đơn giản và dễ học, giúp giảm đáng kể thời gian phát triển dự án.
Lịch sử phiên bản EF 6
EF 6 2013 .NET 4.0 & .NET 4.5, VS 2012
EF 5 2012 .NET 4.0, VS 2012
EF 4.3 2011 .NET 4.0, VS 2012
EF 4.0 2010 .NET 4.0, VS 2010
EF 1.0 (hoặc 3.5) 2008 .NET 3.5 SP1, VS 2008
Lịch sử phiên bản lõi(core) của EF
EF Core 2.0 tháng 8 năm 2017 .NET Core 2.0, VS 2017
Lõi EF 1.1 Tháng 11 năm 2016 .NET Lõi 1.1
EF Core 1.0 tháng 6 năm 2016 .NET Core 1.0
Tại sao lại sử dụng Entity Framework?
Sử dụng Entity Framework sẽ mang lại những lợi ích sau:
- Nếu bạn thực hiện một truy vấn dữ liệu. Bạn có thể sử dụng Linq to Entities để thao tác các đối tượng được tạo từ Entity Framework, có nghĩa là bạn không phải viết mã sql.
- Dễ dàng cập nhật các lớp và lệnh mỗi khi cơ sở dữ liệu thay đổi, giúp bạn tiết kiệm rất nhiều thời gian.
- Entity Framework sẽ tự động tạo các lớp và lệnh thích hợp để chọn, chèn, cập nhật và xóa dữ liệu khỏi cơ sở dữ liệu quan hệ.
- Entity Framework tự động tạo các lớp để truy cập cơ sở dữ liệu, giúp lập trình viên giảm thời gian viết mã để thao tác với cơ sở dữ liệu. Hỗ trợ bạn không mất quá nhiều thời gian để viết mã thao tác trên cơ sở dữ liệu.
Cấu trúc của Entity Framework
Cấu trúc được mô tả ngắn gọn như sau:
EDM (Entity Data Model):
EDM bao gồm 3 phần :
- Mô hình khái niệm (Conceptual Model): Chứa các lớp mô hình và các mối quan hệ của chúng. Nó độc lập với thiết kế bảng cơ sở dữ liệu của bạn.
- Lập bản đồ (Mapping) : bao gồm thông tin về cách mô hình khái niệm được kết nối với mô hình lưu trữ
- Mô hình lưu trữ (Storage Model) : Đây là mô hình thiết kế cơ sở dữ liệu bao gồm các bảng, dạng xem, các thủ tục được lưu trữ, các mối quan hệ và khóa.
LINQ to Entities:
Một ngôn ngữ truy vấn để viết các truy vấn vào mô hình đối tượng (object model). Trả về thực thể được xác định trong mô hình khái niệm (Conceptual model).
Entity SQL:
Đây là một ngôn ngữ truy vấn khác, tương tự như LINQ to Entities.
Object Service:
Object service sẽ chịu trách nhiệm chỉ định quá trình chuyển đổi dữ liệu trả về từ nhà cung cấp dữ liệu khách hàng thực thể thành cấu trúc đối tượng thực thể.
Entity Client Data Provider:
Nhiệm vụ chính của nó là chuyển đổi các truy vấn L2E hoặc Entity SQL thành các truy vấn SQL. Nó được hiểu bởi cơ sở dữ liệu bên dưới. Giao tiếp với nhà cung cấp dữ liệu ADO.Net, nhà cung cấp dữ liệu này sẽ gửi và nhận dữ liệu từ cơ sở dữ liệu.
ADO.Net Data Provider:
Giao tiếp với cơ sở dữ liệu được thực hiện bằng tiêu chuẩn ADO.Net.
Những tính năng của Entity Framework
Các tính năng đáng chú ý nhất của Entity framework:
- Entity framework hỗ trợ stored procedure.
- Nó làm việc với bất kỳ cơ sở dữ liệu quan hệ nào có Entity Framework hợp lệ.
- Entity Framework tạo truy vấn SQL từ LINQ to Entities.
- Nó được phát triển như một sản phẩm mã nguồn mở.
- Entity framework là một sản phẩm của Microsoft.
- EF cho phép tạo những câu lệnh thêm, xóa, cập nhật.
- Theo dõi những thay đổi của các đối tượng trong bộ nhớ.
Các tình huống dùng Entity Framework?
Entity framework là rất hữu ích trong 3 tình huống sau:
Database First: Đầu tiên là nếu bạn đã có cơ sở dữ liệu hoặc muốn thiết kế cơ sở dữ liệu trước khi xử lý phần còn lại của ứng dụng.
Code First: Thứ hai, bạn muốn tập trung vào các lớp miền và sau đó tạo cơ sở dữ liệu từ các domain class đó.
Model First: Thứ ba, bạn thiết kế lược đồ cơ sở dữ liệu trên trình thiết kế trực quan, sau đó tạo cơ sở dữ liệu và các lớp.
Hướng dẫn tạo project và cài đặt Entity Framework trong C#
1. Tạo project C#:
Mở Visual Studio -> tạo một project
2. Cài đặt Entity Framework
Trong mục Solution Explorer, chuột phải lên project -> chọn Manage NuGet Packages…
Click Entity Framework -> chọn Install
Ấn Ok để cài đặt.
Sau đó bạn ấn Chọn I Accept.
Thông báo này sẽ được hiển thị sau khi cài đặt thành công
3. Chuẩn bị cơ sở dữ liệu
Mở SQL Server Management Studio -> kết nối đến server
Tạo một cơ sở dữ liệu tên EntityDB
Trong CSDL tạo một table tên Student gồm có 4 column là StudentID, StudentName, StudentGender và Address
4. Sử dụng Entity Framework
Tạo ADO.NET Entity Data Model
Trong Solution Explorer, chuột phải lên project -> chọn Add -> chọn New Item…
Chọn Visual C# Items -> chọn ADO.NET Entity Data Model -> nhập DatabaseFirstModel -> chọn Add
Chọn EF Designer from database -> chọn Next
Trong trường hợp bạn chọn New Connection… -> chọn tên máy chủ (Server name), chọn cơ sở dữ liệu (Database name) -> chọn OK
Chọn Next
Chọn table và chọn Finish
Xong ấn Ok thêm một lần nữa.
Kết quả sau khi hoàn thành:
DatabaseFirstModel.edmx cần được lưu trước khi viết mã
5. Viết code:
Mở Program.cs và nhập mã sau:
Thêm dữ liệu vào SQL
Chạy chương trình:
Kết quả
Cảm ơn bạn đã xem bài viết của tôi.