介绍
本文档是报表平台的技术架构描述,文中会描述主要的设计思路和设计决策。
架构目标和约束
报表平台作为独立的公共服务产品,可以简单的集成到各产品的报表应用
可维护性和可扩展性
- 扩展运算与分页独立实现,代码更易于维护
- 扩充表达式可以提高报表的运算能力
- 在此报表引擎上可以构建多维分析应用
可用性
- 能适用于上万条记录的报表数据量
- 适用于Web页面显示
易用性
- 针对技术人员,提供类似Excel编辑设计器
- 对多维分析提供专用设计器
- 其他情况下,需要再行开发设计器
实现约束
- 采用XXX实现
- 使用与XXX相同的表达式引擎和类似的表达式语法
- 采用XXX作为显示组件
架构表现
文档描述了系统的主要模型,包括:
- : 从系统外部角度表现重要的参与者和用例
- :以平台独立性提炼用例重要分析元素和用例的分析实现
- :从平台方面描述部署结构、设计元素结构等
用例模型从外部系统的角度描述了系统的行为。
用例模型
- 应用用例:描述用户如何与系统交互以实现预期的功能
用例 | 描述 | 基本要求 |
设计报表 | 报表设计人员通过这个用例设计一张报表 | 通过提供的报表设计器进行报表定义 |
浏览报表 | 使用者通过此用例查看报表数据 | 查看前有些报表需要输入参数 |
预览打印报表 | 使用者通过此用例以分页方式查看报表,并可以打印报表 |
|
填报 | 使用者通过此用例进行业务数据的输入 | 对于上报可能需要自动汇总功能 |
多维分析 | 数据分析人员通过此用例可以从多维度分析数据 | 专有的多维报表设计器,查看报表时提供交互功能 |
- 基础结构用例:描述应用用例的每一步如何添加诸如可用性、可靠性、性能、容错性等质量属性
- 扩展用例
分析模型
架构性重要分析元素
包 | 描述 | 基本要求 |
扩展运算引擎 | 对设计的报表通过模型扩展并进行运算,生成完整的最终报表 | 需要注意扩展和运算的效率 |
分页引擎 | 把最终报表通过分页引擎和分页规则生成多页报表 |
|
数据源 | 提供给报表的数据来源 | 外部定义数据源程序集,实现特定接口 |
表达式引擎 | 实现报表运算中定义的表达式 | 可以扩充表达式增加报表的运算能力 |
报表元数据 | 报表的定义描述文件 | 报表文件以XML方式存储 |
设计器 | 对报表提供统一的表格式设计器,对多维分析提供专有设计器 | 使用ViewGrid控件 |
打印预览 | 以分页方式浏览数据 | 实现轻量级预览控件,减少系统资源 |
架构性重要用例实现
设计模型
设计元素
部署结构
组件结构
更多内容:
欢迎转载,转载请注明:转载自 [ ]