http://blog.csdn.net/leftfist/article/details/25005307

我刚接触EF未久,还不知道它有什么强大之处,但看上去,EF提供了一般的增删改查功能。以往用过一些ORM方法,尽管有代码生成器,但代码量总的 来说比较多。这次采用EF,我就想,能不能尽量写出一些通用的方法,以后添加表、实体类,只需做很少的改动,就能拥有基本的增删改查功能呢?

方案如下:

1、 分为几个部分:BLL、DAL、Model、Interface。其中,EF生成的代码放在Model。因为不想由BLL直接操作Model,因此还是增 加一个DAL,由它来对EF的方法作进一步的封装,供BLL调用。至于接口,则是出于如下考虑:增删改查,BLL和DAL都需要实现,因此它们最好实现同 一接口;最重要的,因为使用了接口,在BLL中,方便调用DAL对象。

这几个部分分别介绍如下:

1、接口Interface

  1. public interface IEntity
  2. {
  3. long _ID { get;}
  4. }
  1. public interface ICommon<T> where T : class,IEntity
  2. {
  3. T Add(T model);
  4. T Update(T model);
  5. void Delete(T model);
  6. //按主键删除,keyValues是主键值
  7. void Delete(params object[] keyValues);
  8. //keyValues是主键值
  9. T Find(params object[] keyValues);
  10. List<T> FindAll();
  11. }

2、DAL

通用的增删改查代码:

  1. public abstract class BaseCommon<T> : Interface.ICommon<T> where T : class,Interface.IEntity
  2. {
  3. DbContext db;
  4. public BaseCommon(DbContext context)
  5. {
  6. this.db = context;
  7. }
  8. public DbContext Context
  9. {
  10. get
  11. {
  12. return db;
  13. }
  14. }
  15. #region ICommon<T>
  16. public T Add(T model)
  17. {
  18. db.Set<T>().Add(model);
  19. db.SaveChanges();
  20. return model;
  21. }
  22. public T Update(T model)
  23. {
  24. if (db.Entry<T>(model).State == EntityState.Modified)
  25. {
  26. db.SaveChanges();
  27. }
  28. else if (db.Entry<T>(model).State == EntityState.Detached)
  29. {
  30. try
  31. {
  32. db.Set<T>().Attach(model);
  33. db.Entry<T>(model).State = EntityState.Modified;
  34. }
  35. catch (InvalidOperationException)
  36. {
  37. T old = Find(model._ID);
  38. db.Entry(old).CurrentValues.SetValues(model);
  39. }
  40. db.SaveChanges();
  41. }
  42. return model;
  43. }
  44. public void Delete(T model)
  45. {
  46. db.Set<T>().Remove(model);
  47. db.SaveChanges();
  48. }
  49. public void Delete(params object[] keyValues)
  50. {
  51. T model = Find(keyValues);
  52. if (model != null)
  53. {
  54. db.Set<T>().Remove(model);
  55. db.SaveChanges();
  56. }
  57. }
  58. public T Find(params object[] keyValues)
  59. {
  60. return db.Set<T>().Find(keyValues);
  61. }
  62. public List<T> FindAll()
  63. {
  64. return db.Set<T>().ToList();
  65. }
  66. #endregion
  67. }

这里面,已经封装好了一般的增删改查方法。而对应数据库每个表对象的那些类,只需继承这个BaseCommon类,即可拥有增删改查功能。如:

  1. public partial class TableA : BaseCommon<Model.TableA> { }

这样,TableA对象会自然拥有增删改查功能。假如需要扩充它的功能,我们可以再写一个TableA的分部类。

以后,新增一个表TableB,在DAL这里,一般情况下只需新增一句:

  1. public partial class TableB : BaseCommon<Model.TableB> { }

是不是很方便?

3、BLL

BLL是供UI层,或者上一层调用的,因此,它每个对象,也应该有增删改查的基本功能。当然,BLL无须直接实现,是通过调用DAL来实现:

  1. public abstract class Common<TDAL, TModel> : Interface.ICommon<TModel>
  2. where TDAL : class ,new()
  3. where TModel : class ,Interface.IEntity
  4. {
  5. protected TDAL dal;
  6. private Interface.ICommon<TModel> common;
  7. public Common()
  8. {
  9. dal = new TDAL();
  10. common = (Interface.ICommon<TModel>)dal;
  11. }
  12. #region ICommon<TModel>
  13. public TModel Add(TModel model)
  14. {
  15. return common.Add(model);
  16. }
  17. public TModel Update(TModel model)
  18. {
  19. return common.Update(model);
  20. }
  21. public void Delete(TModel model)
  22. {
  23. common.Delete(model);
  24. }
  25. public void Delete(params object[] keyValues)
  26. {
  27. common.Delete(keyValues);
  28. }
  29. public TModel Find(params object[] keyValues)
  30. {
  31. return common.Find(keyValues);
  32. }
  33. public List<TModel> FindAll()
  34. {
  35. return common.FindAll();
  36. }
  37. #endregion
  38. }

与DAL类似,TableA对象在这里是这样的:

  1. public partial class TableA : Common<DAL.TableA, Model.TableA> { }

同理,如果以后新增了表TalbeB,在这里也只是新增一句而已。

这里还有一个好处,就是对外界调用而言,根本不需要知道泛型,就是一个 TableA table = new TalbeA();就可以了。

EF学习笔记——通用增删改查方案的更多相关文章

  1. 【转载】ASP.NET MVC Web API 学习笔记---联系人增删改查

    本章节简单介绍一下使用ASP.NET MVC Web API 做增删改查.目前很多Http服务还是通过REST或者类似RESP的模型来进行数据操作的.下面我们通过创建一个简单的Web API来管理联系 ...

  2. ASP.NET MVC Web API 学习笔记---联系人增删改查

    本章节简单介绍一下使用ASP.NET MVC Web API 做增删改查. 目前很多Http服务还是通过REST或者类似RESP的模型来进行数据操作的. 下面我们通过创建一个简单的Web API来管理 ...

  3. MongoDB学习笔记,基础+增删改查+索引+聚合...

    一 基础了解 对应关系 -> https://docs.mongodb.com/manual/reference/sql-comparison/ database -> database ...

  4. Mybatis学习笔记3 - 增删改查示例

    1.接口定义 package com.mybatis.dao; import com.mybatis.bean.Employee; public interface EmployeeMapper { ...

  5. 学习笔记: mysql增删改查基础语句

    mysql基础入门语句 增: INSERT INTO 表名(字段1, 2, 3) VALUES('值1', '2', '3') 删: DELETE FROM 表明 WHERE 删除条件 不提供更新条件 ...

  6. MongoDB学习笔记—03 增删改查操作

    MongoDB的CURD操作分别通过函数insert().update().find().remove()进行 MongoDB文档新增与删除 MongoDB中关于文档的新增与删除比较简单.主要通过in ...

  7. SqlServer存储过程学习笔记(增删改查)

    * IDENT_CURRENT 返回为任何会话和任何作用域中的特定表最后生成的标识值. CREATE PROCEDURE [dbo].[PR_NewsAffiche_AddNewsEntity] ( ...

  8. PHP操作xml学习笔记之增删改查(2)—删、改、查

    xml文件 <?xml version="1.0" encoding="utf-8"?><班级>    <学生>       ...

  9. PHP操作xml学习笔记之增删改查(1)—增加

    xml文件 <?xml version="1.0" encoding="utf-8"?><班级>    <学生>       ...

随机推荐

  1. 编写高效且优雅的 Python 代码

    http://python.jobbole.com/86808/ http://python.jobbole.com/86869/?utm_source=blog.jobbole.com&ut ...

  2. QQ(iOS)客户端的粘性动画效果

    qq的app中要是有新的联系人发消息过来,相应联系人的cell右边会有一个红色的圆圈表示消息条数.如果去触碰那个圆圈,可以发现它竟然会跟着手指的移动而移动. 在一定范围内,手指离开屏幕,会发现红色圆圈 ...

  3. 常用linux命令积累

    ------------------------------不定时更新------------------------------------------------- 1.Ubuntu关机:shut ...

  4. JavaScript数组API

    1.将数组转化为字符串:2种:               1.var str=String(str);                       将数组转化为字符串并分隔每个元素          ...

  5. Oracle job定时器的执行时间间隔学习汇总

      Oracle job 定时器的执行时间间隔也是定时器job 的关键设置,在这一设置上,开始还没掌握,总是不知道怎么写,现总结如下,其实主要是使用了TRUNC.NEXT_DAY .ADD_MONTH ...

  6. 转---- javascript prototype介绍的文章

    JavaScript是基于对象的,任何元素都可以看成对象.然而,类型和对象是不同的.本文中,我们除了讨论类型和对象的一些特点之外,更重要的是研究如何写出好的并且利于重用的类型.毕竟,JavaScrip ...

  7. iOS应用之间跳转

    本篇博文将涉及到以下知识点: app应用跳转的原理解析 如何实现两个app应用之间的跳转 如何实现两个app之间跳转到指定界面 二.应用跳转原理 相信从一个应用跳转到另一个应用大家并不陌生,最常见的莫 ...

  8. 读<jquery 权威指南>[2]-事件

    1.  事件冒泡 阻止事件冒泡的两种方式: event.stopPropagation(); return false ; 2. 绑定事件——bind(type,[data],function) ty ...

  9. 页面路由跳转地址-get方式

    从开始敲代码,一直到现在,总是记不太清页面上的路由应该怎样书写,因此最终还是觉得自己应该提笔写下来以免自己再犯同样的错误! 1.get方式访问页面 http://localhost:3001/arti ...

  10. WCF初探-5:WCF消息交换模式之双工通讯(Duplex)

    双工通讯Duplex具有以下特点: 1它可以在处理完请求之后,通过请求客户端中的回调进行响应操作 2.消息交换过程中,服务端和客户端角色会发生调换 3.服务端处理完请求后,返回给客户端的不是reply ...