前天那篇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即完成了这个实现,而且这样的架构对于模型驱动同样支持,^_^,何乐而不为,鱼和熊掌均可得之(其实就只有熊掌,只是一个可能是肥壮一些的,一个是瘦弱一些的,^_^)。
数据驱动、模型驱动作为如今软件设计中两种不同的模型驱动方法,应该说各有各的优缺点以及适用的场合,不能就一概的去认为哪种必然就是更好的。
数据驱动采用的方式是根据对业务的分析建立数据模型来进行系统设计的一种方法,通过数据模型的建立来完成系统的实现,一般来说,在采取数据模型的系统中多采用的是前台直接和数据模型进行绑定的方式,这样在实现起来相对来讲会非常的快速。根据数据驱动的系统设计以及实现方式上来讲,数据驱动适合于数据型的应用系统的建设,而现在大部分的中小型应用系统很多就停留在这个层面上,在这类系统中数据驱动会显得特别的实用和好用,这类系统一个非常突出的共同点就是系统基本属于信息的录入、显示以及查询这样的一个过程,不存在复杂的数据业务逻辑处理。
模型驱动采用的方式根据对业务的分析建立业务对象模型来进行系统设计的一种方法,通过业务对象模型结合系统架构约束来进行系统的实现,一般来说,在采取模型驱动的系统中多采用N层的结构体系,前台显示一般和业务显示模型进行交互,而业务显示模型则通过业务对象模型进行交互来完成业务逻辑的处理,业务对象模型通过与持久对象模型进行业务持久的处理,在这样的情况下,势必增加了系统的复杂度,模型驱动适合与业务型应用系统的建设,这个在行业化的业务应用上显得比较突出,这类系统的共同点在于业务逻辑较为复杂而且多变,系统不仅仅是信息的录入、显示以及查询,更多的是对录入或显示的信息进行业务逻辑的处理。
经过上面的简单介绍后,我觉得对于数据驱动和模型驱动都会有个大概的概念,只能说数据驱动和模型驱动各有优势,要结合系统需求来选择相应的驱动方式。
对于模型驱动个人有些观点,其实从模型驱动我们可以看出如果采用模型驱动面对一个数据型的应用系统时,最后产生的业务对象模型即退化为了数据模型,只是由于模型驱动通常采用的N层架构此时反而约束了此模型的快速实现,是否应该在模型驱动的N层架构中去考虑一种退化的业务对象模型的支持呢?觉得这点是值得思考的,如果支持的话应该说对于模型驱动非常有利或者说是模型驱动的一个补充,相当于对于模型驱动进行分类处理,有些时候架构不能太S,还是要根据系统建设的需求做出适当的调整。
根据这样的观点,其实数据驱动也是模型驱动,只是它采用的是一种退化的业务对象模型的驱动,并同时进行架构层次的调整以适应系统的快速建设,但数据驱动对于复杂多变的业务逻辑系统来说毕竟难去满足了,主要是会在数据模型的建立以及业务逻辑的修改的方面。
综合这样的观点,还是更为倾向模型驱动,同时也认为,模型驱动的架构应该考虑对于退化的业务对象模型的支持。
分享到:
相关推荐
* 多维数据模型是指将数据按照不同的维度进行分析和建模的方法 * 多维事件模型是指将用户行为数据按照不同的事件维度进行分析和建模的方法 知识点4:数据分析方法 * 行为事件分析是指对用户行为数据进行分析和建模...
5. 系统优化与决策支持:阐述如何利用数字孪生和数据驱动的智能系统进行决策优化。 6. 安全与隐私保护:讨论数字孪生与数据驱动系统中的安全问题及应对策略。 7. 未来趋势与发展挑战:展望数字孪生技术的未来发展,...
Linux操作系统中的总线、设备和驱动模型是Linux内核中重要的组成部分,负责实现硬件设备的枚举、初始化、数据传输、中断处理以及电源管理等。以下是该领域的详细知识点: 1. Linux设备模型概念: Linux设备模型提供...
在Windows操作系统中,驱动程序模型(WDM,Windows Driver Model)是一种统一的框架,用于构建各种类型的驱动程序,包括设备驱动和系统驱动。Windows驱动程序模型设计主要涉及以下几个关键知识点: 1. 驱动程序类型...
SWAT 模型中国大气同化驱动数据集(CMADS V1.0)使用手册 CMADS V1.0 是一个中国大气同化驱动数据集,旨在为 SWAT 模型提供高质量的气象驱动数据。该数据集引入了先进的数据同化模式及 ECMWF 背景场,利用数据模式...
模型驱动的软件开发模式是指在软件开发过程中,使用模型来描述软件系统的结构、行为和功能,通过模型转换和代码生成来自动产生软件代码的开发模式。该模式的研究旨在探讨模型驱动的软件开发模式的理论基础、技术架构...
这个项目提供了基于数据驱动的锂电池寿命预测的完整Matlab实现,结合了实际的数据集,帮助研究人员和工程师理解并应用此类预测模型。 首先,我们要了解锂电池寿命预测的重要性。锂电池广泛应用于电动汽车、储能系统...
3. **数据驱动**:数据驱动方法强调从实际测量数据中直接学习和推断模型,而不是依赖于理论模型或先验知识。在DDRSI中,数据是唯一输入,算法会自动从大量测量数据中学习并识别出模态特性,适用于那些无法建立精确...
基于数据驱动的模型预测控制电力系统机组组合优化matlab 复现《Feature-Driven Economic Improvement for Network-Constrained Unit Commitment: A Closed-Loop Predict-and-Optimize Framework》,程序主要做的是一...
linux内核驱动模型linux内核驱动模型linux内核驱动模型
2. 发展中:企业开始意识到数据驱动能力的重要性,开始建设数据仓库和数据分析系统。 3. 成熟:企业已经完成数据驱动能力的建设,开始应用数据分析结果来支持决策。 4. 高级:企业已经实现了数据驱动能力的自动化,...
【摘要】中提到的这篇论文主要探讨了数据驱动的异常检测与预警问题,涉及的关键技术包括Kσ偏差、加权Topsis模型、指数平滑法和ARIMA模型。以下是这些技术的详细说明: 1. **Kσ偏差**:这是一种常用的统计方法,...
- **PLC通讯**:在工厂自动化中,MCGS可以与PLC(可编程逻辑控制器)通过串口进行数据交换,实现设备控制和数据采集。 - **传感器连接**:通过串口驱动,可以将各种传感器的数据实时传送到MCGS系统,进行数据分析...