ntroducing K-Pattern: A Rapid Way to Make CRUD Operations with Entity Framework
Introduction
Earlier in the last year I made a different approach to work on Entity Framework and in that I made some classes to handle the ObjectContext in single request scope and some extension methods to handle Insert / Update / Delete for all the edmx designer classes. Using that way I realized that how fast we can make applications with it but there are some things which are missing on that way. I worked on those drawbacks and now it’s in front of you.
This article is a remake of my earlier Article/Tip "Best way to use Entity Framework". I’ll describe new features and methods of “Helper.cs” class and will also compare this approach with some other approaches in the market in this article.
Background
Please go through the Part 1 before reading this article to understand the “Global Context” and “Helper” classes. After writing the 1st part, Debates were done among the developers that are is this the “Best way to use Entity Framework”? So to make it more understand it is best because of below things:
- DataContext alive and disposes on
HttpContextbasis so you do not need to write the code for initialize and dispose again and again in code blocks. - The Insert, Delete and Update methods are attached with Data Context Entity classes without any change effect in the original designer file. So developer does not need to write individual functions for these operations for each entity class.
- Single Method for Insert and Update.
- Easy and Fast to implement
However, there are some other patterns that also follow the same rule but there are lot of code involves to making it happen.
What's New?
The previous “Helper.cs” doesn’t allow Insert/Update/Delete operations on relational entities therefore It only works on Single Entity. This was the major drawback but now I have added some new methods to get overcome this issue. There is a new enum Operation introduce to define EntitySet Operations like Added, Modified and Deleted. New extension methods have been defined for three classes EntityObject, EntityCollection<T> and ObjectContext. The list of methods with their classes and signatures are mentioned below:
| Class | Methods | Description |
EntityObject |
AttachMe(this EntityObject objEntity) | Attach the current entity object with defined Global Context in Global.cs. |
| AttachMe(this EntityObject objEntity, Operation oper) | Attach the current entity object with defined Global Context in Global.cs and Change its state according to the provided Operation enum | |
| DetachMe(this EntityObject entity) | Detach the current entity object with defined Global Context in Global.cs | |
EntityCollection<T> |
AttachUs<T>(this EntityCollection<T> entities, Operation oper) where T : EntityObject | Generic method to attach the whole collection with define Global Context in Global.cs |
| DetachUs<T>(this EntityCollection<T> entities) where T : EntityObject | Generic method to attach the whole collection with define Global Context in Global.cs | |
ObjectContext |
AttachObject(this ObjectContext context, EntityObject objEntity) | Attach the provided entity with provided context. |
| AttachObject(this ObjectContext context, EntityObject objEntity, Operation oper) | Attach the provided entity with provided context and change its state according the provided operation. | |
| DetachObject(this ObjectContext Context, EntityObject entity) | Detach the provided entity with provided context. | |
Let's Get Started
To demonstrate the new methods, we are going to make a DB (db_EntityFrameworkSample) and create two tables which have One to Many Relationship between.


In above diagram there are two tables Course and Student and they are associated via One to Many Relationship. We are going to perform operations on these tables in following order.
Single Entity Operations
Collapse | Copy CodeCourse objCourse = new Course
{
Name = "B.Sc.",
Duration = "3 Years"
}; objCourse.Save();
Insert Parent & Insert Children
Collapse | Copy CodeCourse objCourse = new Course
{
Name = "M.Sc.",
Duration = "3 Years"
}; objCourse.AttachMe(); // Here we attached the current object with entity object context to perform operations on children entities objCourse.Students.Add(new Student { Name = "John", FName = "David" });
objCourse.Students.Add(new Student { Name = "Bob", FName = "Jason" }); objCourse.Save();
Update Parent & Insert Children
Collapse | Copy CodeCourse objCourse = Course.GetCourse(2); // Get MCA Cource
objCourse.Students.Add(new Student { Name = "Niroo", FName = "Rob" });
objCourse.Students.Add(new Student { Name = "Chirs", FName = "William" });
objCourse.Save();
Update Parent & Update Children
Collapse | Copy CodeCourse objCourse = Course.GetCourse(2); // Get MCA Course objCourse.Students.ElementAtOrDefault(0).BirthDate = new DateTime(1986, 12, 15);
objCourse.Students.ElementAtOrDefault(1).BirthDate = new DateTime(1990, 7, 15); objCourse.Save();
Update Parent & Delete Children
Collapse | Copy CodeCourse objCourse = Course.GetCourse(4); // Get M-Tech Course objCourse.Duration = "4 Years";
objCourse.Students.AttachUs(Operation.Delete); // Attach student with context and change the EntityState to Deleted objCourse.Save();
Delete Parent & Delete Children
Collapse | Copy CodeCourse objCourse = Course.GetCourse(3); // Get B-Tech Course objCourse.Students.AttachUs(Operation.Delete); // Attach student with context and change the EntityState to Deleted objCourse.Delete();
Above are sample codes which define the data operations between Parent-Child entities with different combinations using "K-Pattern".
Comparision With Repository Pattern
| Feature | K-Pattern | Repository Pattern |
| Easy to implement | YES | NO |
| Context Scope in Single Request | YES | YES (With IOC) |
| Suitable Project Types | Small and Medium Types | Large Type |
| Support for EF Approaches | Database First | Code First and Database First |
Conclusion
This is all about the K-Pattern. Thre are lot of discussion coming along with this approach and I'll be waiting for your reviews and suggestions to improve it better. Please downaload the source code, create the DB with the available SQL Script, chagne the conenction string and run it straight.
Thanks for reading. Happy coding.
License
This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)
ntroducing K-Pattern: A Rapid Way to Make CRUD Operations with Entity Framework的更多相关文章
- Using the Repository Pattern with ASP.NET MVC and Entity Framework
原文:http://www.codeguru.com/csharp/.net/net_asp/mvc/using-the-repository-pattern-with-asp.net-mvc-and ...
- [转]Using the Repository Pattern with ASP.NET MVC and Entity Framework
本文转自:http://www.codeguru.com/csharp/.net/net_asp/mvc/using-the-repository-pattern-with-asp.net-mvc-a ...
- Generic repository pattern and Unit of work with Entity framework
原文 Generic repository pattern and Unit of work with Entity framework Repository pattern is an abstra ...
- Using Repository Pattern in Entity Framework
One of the most common pattern is followed in the world of Entity Framework is “Repository Pattern”. ...
- IMPLEMENTATION - Entity Framework Anti Pattern - High Performance EF
Good about ORM Developer is free from building T-Sql on the database tier which is not their major a ...
- 5.在MVC中使用泛型仓储模式和工作单元来进行增删查改
原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-operations-using-the-generic-repository-pat ...
- 在MVC中使用泛型仓储模式和工作单元来进行增删查改
原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-operations-using-the-generic-repository-pat ...
- 6.在MVC中使用泛型仓储模式和依赖注入实现增删查改
原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-operations-using-the-generic-repository-pat ...
- 1.【使用EF Code-First方式和Fluent API来探讨EF中的关系】
原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/relationship-in-entity-framework-using-code-firs ...
随机推荐
- linux系统无法挂载U盘
插上U盘 [ 2407.650440] usb 1-3.3: new high speed USB device number 7 using s5p-ehci [ 2407.887332] usb ...
- iSCSI存储的3种连接方式
我们分析了iSCSI存储的系统结构,下面来看iSCSI是如何与服务器.工作站等主机设备来连接的,也就是我们如何建立一个iSCSI网络存储系统. iSCSI设备的主机接口一般默认都是IP接口,可以直接与 ...
- laravel安装初体验
1.github下载laravel 2.通过composer安装相应的库 composer config repo.packagist composer https://packagist.phpco ...
- PHP中静态变量的使用
1.定义静态变量 public static $endpoint,$accessKeyId,$accessKeySecret,$bucket; 2.静态变量赋值 protected function ...
- C++对Lua中table进行读取、修改和创建
C++代码: // LuaAndC.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream> #i ...
- Vue源码学习(一):调试环境搭建
最近开始学习Vue源码,第一步就是要把调试环境搭好,这个过程遇到小坑着实费了点功夫,在这里记下来 一.调试环境搭建过程 1.安装node.js,具体不展开 2.下载vue项目源码,git或svn等均可 ...
- linux 挂载硬盘
fdisk -l mkfs.ext4 /dev/vdb mkdir /data mount -t ext4 /dev/vdb /data 编辑/etc/fstab /dev/vdb /data ext ...
- kali下安装go环境
1.安装go 下载安装包,命令:wget -c https://storage.googleapis.com/golang/go1.8.3.linux-amd64.tar.gz 下载完后,解压到 /u ...
- CVE-2017-11882复现配合koadic
项目地址:https://github.com/iBearcat/CVE-2017-11882 首先开启koadic,然后配置一下 复制这句代码 mshta http://192.168.220.13 ...
- hardentools
Hardentools是一组简单的实用程序,旨在禁用操作系统(Microsoft Windows,现在)以及主要的消费者应用程序公开的许多“功能”.这些通常为企业客户所设想的功能,对于普通用户来说通 ...