1、1.单表数据模型2.自连接数据模型3.一对一数据模型4.一对多数据模型5.一对多数据模型中的一张表是自连接6.多对多数据模型7.多对多数据模型中的一张表是自连接关键字包括1.查询2.状态3.上传4.工作流架构图组件说明图表 1项目组件说明图1)App页面展示层采用MVC框架,使用Jquery脚本库,控件选用Easyui。2)WcfHost服务宿主(后期扩展)为对外的服务提供宿主,使用WCF技术,HTTPS通讯协议。3)IBLL业务接口层业务逻辑层的方法对外暴露的接口和服务契约。4)BLL业务逻辑层业务逻辑的操作,包括业务处理,事务,日志。5)DAL数据访问层数据库访问的操作,数据实体,业务实体
2、,数据校验,使用Entity Framework。6)Common公共组件层整个应用程序使用的公共辅助方法。7)WFActivitys工作流活动层(后期扩展)定义了工作流需要的活动,使用微软WF技术。8)WFDesigner工作流设计器(后期扩展)可以让实施人员自由配置工作流的设计器,使用微软WPF技术。人员的作用使用人员的用户名和密码登陆系统人员和部门之间有一张关联表,而部门是一个典型的自连接表 ,这三张表就构成了一个典型的“多对多数据模型中的一张表是自连接”下面我们以人员为例子分析“多对多数据模型中的一张表是自连接”数据模型,代码已在生成的文件中,并且注释详备,此文不再赘述数据模型部门和人
3、员之间是多对多的关系,而部门又是一张自连接的表查询列表页面展示层AppMvc中的View的代码此列表页面是参照jquery-easyui-1.2.3demotree.html页面开发的Mvc中的Controller的代码Mvc中的Model的代码Model就是Entity Framework自动生成的实体业务接口层IBLL此层作为业务逻辑层方法的接口,也是WCF对外暴露的契约业务逻辑层BLL数据字典类的业务逻辑写在BLL类库中,事务使用TransactionScope对象,SysPersonBLL.cs类文件里面封装了业务逻辑的操作方法,并且继承了BaseBLL基类整个项目应该遵循的原则是:胖
4、BLL,瘦mvc数据访问层DAL其中SysPerson.cs文件放置的是表的实体和实体元数据的验证,而SysPersonRepository.cs文件放置的是访问数据库的方法业务实体在SysPerson.cs文件中的SysPerson类,它是一个分部 partial 类,内部可以自定义属性,MetadataType属性中指定了该实体属性的校验类SysPersonMetadata,并且它继承了IBaseEntity接口(此接口暂时没有任何成员);SysPerson.cs文件中还有一个SysPersonMetadata类用于校验SysPerson类中的成员。注意校验类需要引用using System.ComponentModel.DataAnnotations;命名空间。服务层(后期扩展)删除先选中一条,然后点击删除 创建选择部门(树形结构)选择角色(非树形结构)修改查看详细信息 .