千淘万漉虽辛苦,吹尽狂沙始到金

------记录,收集跟技术相关的文章,工具,软件

Repository 设计模式介绍

仓储(Respository)是存在于工作单元和数据库之间单独分离出来的一层,是对数据访问的封装。其优点:

1)业务层不需要知道它的具体实现,达到了分离关注点。

2)提高了对数据库访问的维护,对于仓储的改变并不会改变业务的逻辑,数据库可以用Sql Server

 

我们使用repository来将业务层和数据实体层分开来,业务逻辑层应该对组成数据源层的数据类型不可知,比如数据源可能是数据库或者Web service


在数据源层和业务层之间增加一个repository层进行协调,有如下作用:


1.从数据源中查询数据

2.映射数据到业务实体

3.将业务实体数据的修改保存到数据源 (持久化数据)

这样repository就将业务逻辑和基础数据源的交互进行了分隔。


数据和业务层的分离有如下三个优点:


1.集中管理不同的底层数据源逻辑。

2.给单元测试提供分离点。

3.提供弹性架构,整体设计可以适应程序的不断进化。

我们将会对原有做法进行两轮抽象,实现我们想要的效果。

仓储和工作单元模式是用来在数据访问层和业务逻辑层之间创建一个抽象层。

应用这些模式,可以帮助用来隔离你的程序在数据存储变化。

下图比较了不使用库模式和使用库模式时controller和context 交互方式的差异。

说明:库模式的实现有多种做法,下图是其中一种。