关于UnitOfWork

按照http://martinfowler.com/eaaCatalog/unitOfWork.html这篇文章的介绍,UnitOfWork是为了维护对象的变化,A Unit of Work keeps track of everything you do during a business transaction that can affect the database。如果是这样的花,对于ef来说,继承DbContext类都可以看作是unit of work,而dbset<>可以看作是repository, 最终都通过savechanges来完成所有变化的持久化。

如果项目只是用EF,不考虑以后使用其他ORM的可能的话,个人认为没有必要使用unitofwork.对于EF来说本身就实现了这部分功能。

如果考虑今后变化的可能,那需要自己来实现IunitOfWork  和 IRepository  来应对今后的变化,实现对ORM的解耦。

 

类似的,对于使用的IOC,来说,为了应对未来的变化,也可以有类似的思考,比如有当前使用的autofac,转为使用其他的IOC容器。Common Service Locator就是为了应对这种变化,在IOC容器和Service LOcator 之上抽象的一个类库。实现对IOC容器的解耦

转载于:https://www.cnblogs.com/fuyujian/p/4567433.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值