由于工程应用环境的特殊性,因此传统的以事务处理为目标的数据库管理系统如关系模型管理等都无法适应要求,因此需要一种能适应工程应用的数据库管理系统。为此,首先需要了解工程应用中数据管理的一些特点。
1.表示复杂数据结构的能力
在工程应用中,工程对象形式多样,它们之间又存在多种关联,因此需要有一种既能构造各不同对象又能建立相互关联的数据结构,这就要求工程数据库具备表示与构造复杂数据结构的能力。
2.表示变长数据的能力
变长数据是工程数据的一大特点,而传统数据库中的结构类型无法表示此类数据,这就要求工程数据库具有表示变长数据的能力。
3.可扩展数据类型的能力
在工程应用中,数据类型复杂、多样,因此除了一些基本类型之外,还要具备随时根据数据需要生成新类型的能力。
4.对数据模式能做动态修改与扩充
在工程应用中,经常会碰到复杂的应用设计,它们很难一次性完成设计而必须在设计、应用中边修改、边使用,在使用中积累经验,不断修改,这其中也包括对数据模式的设计。因此,工程数据库在工程领域中的应用及工程数据库介绍287数据管理应具有不断修改、扩充数据模式的能力,这种能力一般称之为模式演化(schema evolu-tion)。
5.图形数据表示与处理能力
由于工程应用中的数据处理对象大多是工程图纸及相应的图形,因此工程数据管理应具有对图形进行表示与处理的能力。
6.版本管理
在工程应用中,一个完整的设计过程必须经过多个方案不断地试探、比较以及修改而形成,而每个新方案又是对以前旧方案进行修改而形成的,因此需要保留不同的设计方案以为今后的改进提供保障。而每个设计方案就是一个工程设计版本,它由一群数据体组成,对不同方案的保存与管理就是所谓的版本管理或称版本控制(version control)。因此,在工程数据管理中需要有版本管理的能力。
7.长事务处理能力
在工程应用中,工程师经常需要花费几个小时甚至几天时间连续对某个工程项目做设计,这是一种交互式长事务处理作业。在这段时间内,该工程师必须独占系统资源,特别是数据资源,这就要求数据管理能具有并发控制中的长事务处理能力。
从以上7点可以看出,工程数据管理具有传统数据管理所没有的特殊要求,在这7点之上所构造的数据库管理系统即可称为工程数据库管理系统。
工程数据管理一般包括三个方面功能:
1.定义用户产品,维护物料清单(BOM),包括制造与工程设汁的物料清单,为用户提供完整而准确的物料信息;
2.维护工艺路线信息,描述被加工工件的加工过程,诸如加工地点和制造顺序;
3.标准成奉核算,提供既快又准确的成本计算信息支持。
工程数据管理按发展时段可分为人工管理、文件管理和数据库管理三个阶段。数据管理的三个阶段及其特点见下表。
人工管理阶段 | 文件管理阶段 | 数据库系统阶段 | ||
背景 | 应用背景 | 科学计算 | 科学计算、管理 | 大规模管理 |
硬件背景 | 无直接存储设备 | 磁盘、磁带、磁鼓 | 大容量磁盘 | |
软件背景 | 无操作系统 | 有文件系统 | 有数据库管理系统 | |
处理方式 | 批处理 | 联机实时处理、批处理 | 联机实时处理、分布处理、批处理 | |
特点 | 数据的管理者 | 用户(程序员) | 文件系统 | 数据管理系统 |
数据面向的对象 | 某一应用程序 | 某一应用 | 现实世界 | |
数据的共享程度 | 无共享、冗余度极大 | 共享性差,冗余度大 | 共享性好、冗余度小 | |
数据的独立性 | 完全依赖于程序 | 独立性差 | 有高度的物理独立性和一定的逻辑独立性 | |
数据的结构化 | 无结构 | 记录内有结构,整体无结构 | 整体结构化,用数据模型描述 | |
数据控制能力 | 应用程序自己控制 | 应用程序自己控制 | 由数据库管理系统提供数据安全性、完整性、并发控制和恢复能力 |
人工管理阶段是在20世纪50年代中期以前,计算机主要用于科学计算。当时的硬件状况是,外存只有纸带、卡片、磁带,没有磁盘等直接存取的存储设备;软件状况是,没有操作系统,没有管理数据的软件;数据处理的方式是批处理。人工管理的特点是数据不保存,应用程序管理数据,数据不共享,不具有独立性。这种方式已随着计算机技术的发展和生产水平的提高而被摒弃。
人工管理阶段 | 文件管理阶段 | 数据库系统阶段 | ||
背景 | 应用背景 | 科学计算 | 科学计算、管理 | 大规模管理 |
硬件背景 | 无直接存储设备 | 磁盘、磁带、磁鼓 | 大容量磁盘 | |
软件背景 | 无操作系统 | 有文件系统 | 有数据库管理系统 | |
处理方式 | 批处理 | 联机实时处理、批处理 | 联机实时处理、分布处理、批处理 | |
特点 | 数据的管理者 | 用户(程序员) | 文件系统 | 数据管理系统 |
数据面向的对象 | 某一应用程序 | 某一应用 | 现实世界 | |
数据的共享程度 | 无共享、冗余度极大 | 共享性差,冗余度大 | 共享性好、冗余度小 | |
数据的独立性 | 完全依赖于程序 | 独立性差 | 有高度的物理独立性和一定的逻辑独立性 | |
数据的结构化 | 无结构 | 记录内有结构,整体无结构 | 整体结构化,用数据模型描述 | |
数据控制能力 | 应用程序自己控制 | 应用程序自己控制 | 由数据库管理系统提供数据安全性、完整性、并发控制和恢复能力 |
1.文件管理系统
工程数据管理技术同事务管理相类似也是从文件管理系统开始发展起来的,这里的文件系统有两层含义:一是计算机辅助设计的整个过程,即从设计开始,及随之的分析、计算、绘图,均用文件作为相互间传递信息的媒介;二是面向不同应用的计算机辅助设计作业,及不同的系统之间均以文件的方式来传送信息。文件系统中应用程序与数据之间的对应关系如图2所示。
2.基于数据库管理系统
数据库系统中应用程序与数据库之间的对应关系如图3所示。
基于数据库管理系统(Data Base Management System,DBMS)实现工程数据管理如图4所示。
这种环境适用于先进的系统或CAD工作站,在此环境下用户可开发他们自己的应用程序。一般采用层次结构易于实现对实际设计过程的管理,能保证大量数据相互无关,但随着用户或应用的增多,性能会下降。
3.基于局部区域网络的管理系统
基于局域网络(Local Area Network,LAN)的工程数据管理系统结构如图5所示。多数CAD工作站均具有这种形式的联网功能,在这种结构下实现数据的分布处理、资源共享,系统结构灵活、便于扩展、易保证数据无关。
4.分布式管理系统
为适应远程多用户的需要而发展起来的分布式管理系统如图6所示。这是当前工程数据管理系统的一种新技术,采用先进的网络通信、局部数据库和系统数据库相结合的工作方式,克服了基于局部区域网络进行工程数据管理系统的缺陷,但随之由于无中心数据词典(难以建立这种词典),又给保证数据的完整性、实现并发管理带来困难,并且当一个节点破坏时常常有需要重新构造系统的危险。