代码生成工具Database2Sharp中增加视图的代码生成以及主从表界面生成功能

在代码生成工具的各种功能规划中,我们一向以客户的需求作为驱动,因此也会根据需要增加一些特殊的功能或者处理。在实际的开发中,虽然我们一般以具体的表进行具体业务开发,但是有些客户提出有时候视图开发也是很常见的,为了提高代码生成和界面生成的效率,基于视图开发的过程也应该支持。还有主从表的界面生成操作,在很多实际的业务领域也是很常见的。基于上面的需求,本次代码生成工具Database2Sharp中增加视图的代码生成以及主从表界面生成功能,为客户的高效率开发快马加鞭、保驾护航。

1、基于视图的代码生成和界面生成操作

为了支持视图的相关代码生成,我们把代码生成工具底层的元数据进行了优化整合,是指在代码生成方面,具体的表和视图不再有具体的差异,基本上都是可以统一对待,实现快速的框架代码生成、Winform界面生成、Web界面生成操作的,所有的表的相关属性,视图也具有,因此在代码模板方便,不需要进行调整,兼容了代码模板的属性处理,提高了已有代码模板的安全性。

代码生成工具Database2Sharp中增加视图的代码生成以及主从表界面生成功能

如上所示,为了区分表和视图的位置,我们把视图统一放在了表的后面,方便选择处理,在选择的时候,表和视图都是一视同仁,所以代码生成的处理适用于表的,也是适用于视图的,可以统一一并生成,极大的提高了代码生成的效率。

当然,视图的增删改操作,和表毕竟不一样,一般视图只是为了查询数据进行展示的,所以在实际开发的时候,可以适当屏蔽视图的增删改操作,或者自定义相关的接口进行处理。

在Winform界面的生成的时候,我们也一样整合了视图的列表,可以基于视图进行界面代码的生成。

不过我们注意到,一般表我们使用备注信息作为Winform界面的字段说明信息的,如果是视图,那么是无法获取到它的视图字段备注信息的,因为视图的字段备注是不存在的,为了实现和表一样具有中文备注的界面,我们增加了一个对视图字段进行备注信息维护的界面,有着字段的备注,我们生成Winform界面的时候,对应字段的标签就有中文信息了。

代码生成工具Database2Sharp中增加视图的代码生成以及主从表界面生成功能

通过Enterprise Library架构生成的相关代码,也同时具有相关的备注信息,如下代码所示。

代码生成工具Database2Sharp中增加视图的代码生成以及主从表界面生成功能

通过代码生成工具里面的Winform界面代码生成,当然也会具有相关的备注信息,可以在界面上显示对应的中文标签信息了。

视图的Winform界面代码生成和普通的表生成的Winform界面操作过程一样,具体界面操作如下所示。

代码生成工具Database2Sharp中增加视图的代码生成以及主从表界面生成功能

这样生成的Winform界面操作和普通表的处理方式一致,而且对应的视图字段也有了备注信息,因此在界面上的标签说明也就和表一样,可以显示备注信息了。

2、主从表的界面生成操作

在有些情况下,有些业务表是具有主从关系的,如一个是汇总信息,一个是明细信息,如仓库的入库、出库操作,会员的消费操作,都是典型的主从表应用场景,可以把它们作为一个界面生成的案例进行处理。

标准的主从表界面如下界面所示。

代码生成工具Database2Sharp中增加视图的代码生成以及主从表界面生成功能

或者会员消费信息的横向界面展示如下所示。

代码生成工具Database2Sharp中增加视图的代码生成以及主从表界面生成功能

在我之前的代码生成界面里面,主要是生成标准的分页列表展示,以及编辑明细两个标准界面,为了更加丰富开发工具的界面生成,根据上面两种界面的综合情况,增加一个主从表的界面生成操作,这样可以更加适应实际的业务开发工作,高效进行界面的快速生成。

如在代码生成工具里面,设置主从表的界面生成如下所示。

代码生成工具Database2Sharp中增加视图的代码生成以及主从表界面生成功能

生成Winform界面代码后,在VS编辑器里面,可以看到如下所示界面。

代码生成工具Database2Sharp中增加视图的代码生成以及主从表界面生成功能

最后在实际程序上运行生成的界面,就可以看到预览的界面效果了,界面效果如下所示。

代码生成工具Database2Sharp中增加视图的代码生成以及主从表界面生成功能

为了方便,上面界面增加了一个复选框,用来切换横向或者纵向展示明细列表的,勾选后进行横向显示,如下所示。

代码生成工具Database2Sharp中增加视图的代码生成以及主从表界面生成功能

上面主从表的展示,还包括了明细表信息的汇总功能,这样基本上满足了主从表的信息展示了,如果需要,还可以在这基础上进行更方便的改进了。

上一篇:CNUOJ 535 黑魔法师之门


下一篇:MockPlus原型设计介绍