继续侃数据驱动和模型驱动

前天那篇blog更多的是讲了下数据驱动、模型驱动的大致概念,今天更多的是讲数据驱动以及模型驱动在进行系统实现时的方法以及过程。
数据驱动
采用数据驱动进行系统实现时通常采用的是一个这样的过程,建立数据源(DataSource),同时根据业务对象模型进行数据库表设计,在数据库表设计完成后根据业务场景构成数据集(DataSet),通常这个时候DataSet本身就是一种业务场景所需的业务数据,在简单的情况下有可能就是对某张表的操作,复杂的情况下则是对于多张表的操作,在DataSet构成后将此DataSet绑定到页面即可进行数据的展现了,如需对数据进行增加、编辑、删除同样通过DataSet方式来进行,这个过程基本上就是一个基于数据驱动进行系统实现的过程了。
模型驱动
采用模型驱动进行系统实现时通常采用的是一个这样的过程,根据业务场景建立业务对象,在进行持久时持久业务对象中需要持久的属性,对于业务场景的实现通过Facade模式对外提供统一接口,此接口通过与持久层进行交互以及操作业务对象(或领域对象)来完成业务场景的实现,而页面则通过此领域对象或显示对象来进行数据的展现,如需对数据进行操作按照显示对象--->Service Facade来完成。

从上面关于实现的过程的描述上来说,会觉得好像模型驱动更为复杂,但模型驱动较之数据驱动的优点我想不用多少,这里更重要的是我觉得是对于数据驱动和模型驱动的一个理解,其实数据驱动同样是模型驱动,呵呵,数据驱动中的业务对象模型我们可以认为和模型驱动中的业务对象模型一致,其和模型驱动的不同点在于数据驱动采用DataSet的方式来实现业务场景,而模型驱动通常采用Service Facade调用各领域对象来实现业务场景,这里有一点非常明显,数据驱动只适合一种简单的业务场景,那就是通过数据关联或简单的数据逻辑处理可以来实现的业务场景,而Service Facade其实对于两者均通用,通过构建类似DataSet的数据关联或简单的数据逻辑处理通过和持久层交互即同样达到了如此的目的,^_^,而且这种方式对于复杂的业务场景同样可以实现,通过领域对象的交互即可完成,而在DataSet方式中这个步骤是比较棘手的,虽然也可以处理,但会带来的问题就是重复代码的增多以及可维护性的降低,其实关键的问题就是其没有形成对象,内聚性不够强。
我的观点仍然是数据驱动是一种退化的模型驱动或者说变相的模型驱动,数据驱动中根据业务对象模型进行数据库表设计的这个过程可以映射为在模型驱动中进行业务对象模型实现的过程,而建立数据集的过程则和模型驱动中的Service Facade颇为相似,只是其Service Facade中的方法比较简单,至于DataSet绑定到页面这个过程其实和模型驱动中将领域对象或显示对象和页面绑定是相同的概念。
模型驱动思想才是王道, ,需要的仅仅是架构体系中对于数据驱动这种变相的模型驱动也提供一个良好的支持,其实我觉得通过上面的描述已经可以看到要去做出这个支持是非常简单的一件事,抽象形成通用Service Facade以及考虑如何建立DataSet即完成了这个实现,而且这样的架构对于模型驱动同样支持,^_^,何乐而不为,鱼和熊掌均可得之(其实就只有熊掌,只是一个可能是肥壮一些的,一个是瘦弱一些的,^_^)。

posted on 2005-11-25 21:47 BlueDavy 阅读(3855) 评论(5)  编辑  收藏 所属分类: 系统设计

评论

# re: 继续侃数据驱动和模型驱动 2005-11-28 11:04 corlin

讲的好,其实模型驱动主要的一点要求是可配置,可扩展。需要的模式倒不限定上面几种。基础的业务模型要很持久,字段/表的扩展对设计和开发人员来说要高效和简洁。界面由多个实体合成,实体是配置好的业务模型实例,实例有一个父实例,实例和实例之间有关联。
屏蔽了数据层,设计和开发人员只需要关心业务。  回复  更多评论   

# re: 继续侃数据驱动和模型驱动 2005-12-30 16:45 weide

最近再次凿摸关于模型与建模,又有所得:其实jerry兄所言两种“数据驱动”和“模型驱动”都是宏观意义上模型驱动开发的特例,二者分别对应的模型不同,数据模型--领域对象模型?  回复  更多评论   

# re: 继续侃数据驱动和模型驱动 2005-12-30 19:57 Programmer's Life

恩,^_^,是的,意思就是这个...
其实用某种角度去看,数据模型也是领域模型,只是一种退化的而已  回复  更多评论   

# re: 继续侃数据驱动和模型驱动[未登录] 2008-06-22 22:31 garfield

对与数据驱动与模型驱动, 我的理解是这两种方式主要差别在于他们的配置,扩展方式的不同。对于数据驱动的配置、扩展 主要体现在数据库表的设计上, 模式驱动的配置、扩展主要体现在编程语言上的设计上。 这两种设计思想实际上没有什么不同, 就是具体实现上不一样。这个主要看设计者习惯用那种方式。  回复  更多评论   

# re: 继续侃数据驱动和模型驱动 2012-09-02 12:32 www.zrpmw.com

写的太有水平了吧!向你学习了  回复  更多评论   


只有注册用户登录后才能发表评论。


网站导航:
 

公告

 









feedsky
抓虾
google reader
鲜果

导航

<2005年12月>
27282930123
45678910
11121314151617
18192021222324
25262728293031
1234567

统计

随笔分类

随笔档案

文章档案

Blogger's

搜索

最新评论

阅读排行榜

评论排行榜