用DBContext (EF) 实现通用增删改查的REST方法
我们用ADO.NET Entity Data Model来生成实体类后,一般都会对这些类进行基本的增删改查操作,如果每个类都要写这些基本的方法,实在太乏味了。下面就是通过step by step的方式介绍如何用DBContext来实现通用增删改查的REST方法,以及实现过程中容易出现的问题。
1. 打开vs2012,新建一个class library的项目
2. 新加一个ADO.NET Entity Data Model项到这个项目
3. 打开App.Config, 修改res://* 为res://yourproject
否则会报下面的这咱错误:
WIFI.ssdl(3,4) : error 0019: Each type name in a schema must be unique. Type name 'WifiModel.Store.AD' was already defined.
4. Build这个项目
5. 新建另一个web api的项目
ASP.NET MVC 4 Web Application –> Web API 模板
注意这个项目的EF的版本与上个项目的版本要一致
6. 添加一个类到Models下:
public class GenericDBContext<T> : WifiEntities where T : class { public DbSet<T> Items { get; set; } public List<T> Get() { return Set<T>().ToList(); } public T Get(int id) { return Items.Find(id); } public void Put(T item) { Items.Attach(item); Entry(item).State = EntityState.Modified; SaveChanges(); } public void Post(T item) { Items.Add(item); SaveChanges(); } public void Delete(int id) { Delete(Get(id)); } public void Delete(T item) { Items.Attach(item); Entry(item).State = EntityState.Deleted; SaveChanges(); } }
7. 添加一个到Controllers下面:
public class GenericController<T> : ApiController where T : class { private readonly GenericDBContext<T> _context = new GenericDBContext<T>(); public List<T> Get() { return _context.Get(); } public T Get(int id) { return _context.Get(id); } public void Post([FromBody]T t) { _context.Post(t); } public void Put([FromBody]T t) { _context.Put(t); } public void Delete(int id) { _context.Delete(id); } }
至此,通用方法写完了
8. 下面就可以写具体Controller了
public class ADController : GenericController<AD>
{
}
…
9. 最后用soap ui 进行调试,通过
如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!欢迎各位转载,但必须在文章页面明显位置给出作者和原文连接,否则保留追究法律责任的权利。
分类:
c#
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?