英文原文
用 ibm rational xde developer for java 为 db2 udb 数据库建模
enter a subtitle
suita gupta(suitag@my.ibm.com),developer technical support,ibm
nanda pilaka(nandap@us.ibm.com),developer technical support,ibm
2004 年 6 月
内容 简介 开始之前 为数据库和表空间建模 表及其关系
视图
存储过程 触发器 基于数据模型生成 ddl 脚本 连接数据库 逆向工程 比较和同步模式 结束语
简介
参与数据库应用程序开发的每一个人都遵循着某套方法。而您所选择的方法将帮助您分析需求,以及开发和交付最终的产品。这套方法中最重要的部分就是,基于业务需求的数据库设计和建模。在这篇文章中,我将谈论使用“rational® xde developer for java”进行的,专门针对“db2® universal database”的设计和建模!
统一建模语言(uml)是用于为业务和软件应用需求建模的标准的图形化表示法。过去的几年里,已经开始广泛地将 uml 用于面向对象的软件开发中。除了适用于为对象建模之外,uml 还适用于设计和建立数据存储模型,以供您的应用程序使用。基本上,数据建模包括分析客户需求,用以开发一个客户的数据需求模型,然后,以该模型为蓝图或架构为应用程序构建数据库。
本文将向您展示基于已熟悉的 db2 sample 数据库来生成一个数据库模型是多么容易。在文章的末尾,您将看到如何为 db2 sample 数据库及其中的一些数据对象建模。我们还将向您展示如何从已完成的模型生成 ddl 脚本,以及如何使用这些脚本来创建最终的 db2 数据库。
我们将使用 rational xde developer for java(版本:2003.06.00)和 ibm db2 universal database v8.1 进行建模。rational xde 支持遵循 ansi sql 92 标准的从 v5.2 开始的所有 db2 udb 版本和 db2 for os/390® 5.x、6.x、7.x 的数据建模。rational xde 也可以用于为 oracle、sybase 和 sql server 数据库建模。
数据建模的好处
数据建模有许多优点,可以使开发小组中的数据设计师和管理员以及所涉及的程序员均从中受益。
数据库设计师可以使用 rational xde 等工具来建立和可视化数据库模型,确保数据库规则,添加不同的数据库对象,并设置关系。 数据库管理员既可以为一个已经存在的数据库创建模型,也可以从模型生成 ddl 并为特定的实现创建数据库。 数据模型有助于应用程序开发人员更好地理解应用程序的总体架构,尽管一般说来,他们不需要深入了解数据库体系结构的细节。他们可以用数据模型来建立类模型,例如由表结构产生。 数据模型对于终端用户也十分有用,可验证是否已准确地捕获所有的数据需求。
如果项目中的所有建模都是用 uml 完成的,那么该数据模型将完全匹配其余的系统设计,并且帮助整个小组无缝地协同工作。
开始之前
在开始创建数据库模型之前,让我们来看一个 rational xde 的屏幕快照,以及我们将用于建立数据库模型的菜单和选项,如 图 1 所示:
图 1. 从 rational xde 开始
我们需要为数据模型创建一个项目。单击 file -> new -> project。选择创建 data modeling project 并命名为“data model”。一旦创建了该项目,您就可以在 model explorer 窗格上看到它了,如下面的 图 2 所示。
其中,已经为您创建了两个模型 —— 一个物理数据模型和一个逻辑数据模型。数据架构师和数据库设计师通常使用逻辑数据模型,以一种独立于特定数据库实现的形式捕获数据需求。逻辑模型是用于与业务风险承担者(stakeholder)进行通信以确保清晰地捕获数据需求的好工具,因为它没有牵扯到特定数据库的细节。数据库设计师通常将逻辑模型细化为一个或多个“范式”,以便消除数据重复和提高最终设计的质量。一旦对逻辑数据需求的准确性有了十足把握,您就可以将该逻辑模型转换为物理数据模型,从而将该模型匹配特定的目标数据库。然后,可以针对特定的数据库系统或应用程序,改进和优化该物理数据模型。
逻辑数据模型的使用不属于本文的讨论范畴。接下来,我们将关注物理数据模型层次上的数据库设计。
图 2. model explorer
为数据库和表空间建模
首先,我们将创建数据库模型。正如您将在下面 图 3 中看到的,数据库是可以进行建模以及在数据模型中用 uml 符号 <<database>> 表示的最大元素。rational xde 允许您选择任何一种它所支持的 dbms 作为数据模型的实现数据库。本文中,我们选择了 db2 udb v8 来演示数据建模的过程。
创建数据库组件
在 model explorer 中,右击 main ->add data modeler ->database。
图 3. 创建数据库模型
然后,单击 model explorer 中新创建的数据库组件,输入一个名称。我们将 sampledb 作为我们数据库的独有名称。
右击 model explorer 中的 sampledb,并单击 data modeler -> open specification。
图 4. 打开 specification
在 database specification 对话框中,在 database 列表中选择 ibm db2 8.x 作为目标数据库。
图 5. 选择目标数据库
单击 ok,并将该数据库组件拖放到 diagram 视图上。
rational xde 允许您建立表空间模型,并将表指派到这一表空间。我们将看到如何建立一个名为 sample_tbsp 的、已分配一个容器的表空间模型。请注意,您在以下步骤中指定的容器路径应该已经存在。
在进一步继续之前,您可以通过右击 model explorer 中的 logical data model 来选择逻辑数据模型。您可以随时使用热键 ctrl+s 保存您的模型。
创建表空间
在 model explorer 中,右击数据库后单击 add data modeler -> tablespace。
图 6. 添加表空间
在 model explorer 中,右击新的表空间并单击 data modeler -> open specification。
在 general 选项卡中,输入表空间的名称,例如 sample_tbsp。您还可以指定其他细节,例如表空间的类型、扩展块大小、预取大小、页面大小以及缓冲池名称。
图 7. 表空间的具体指定
完成后,单击 ok 并将这个表空间组件拖放到 diagram 视图上。您一旦建立了数据库模型和表空间模型,rational xde 就会自动地创建数据库和表空间之间的依赖关系,如下面图 8 所示:
图 8. 依赖关系
创建容器
在 model explorer 中,右击一个表空间后单击 data modeler -> open specification。
在 container 选项卡中,单击 new 图标,并输入新容器的路径名称。
图 9. 定义容器
检查点:您的模型现在应该如 图 10 所示:
图 10. 此时的模型
表及其关系
我们将为原有的 sample 数据库中的两个表(employee 表和 department 表)建模。我们还将为这两个表之间的参照完整性关系建模。
创建表组件的步骤:
在 model explorer 中,右击数据模型,然后单击 add data modeler ->table。 在 table specification 对话框的 general 选项卡中,指定表名称,并在 columns 选项卡中添加该表的列。您还可以为该表指定主键。
图 11. 给模型添加一个表
单击 ok,您将在 model explorer 中看到这个表组件。将之拖放至 diagram 视图上。
我们将分别为 employee 表和 department 表执行以上步骤。对于 employee 表,我们将省略“workdept”列的创建。在我们建立 employee 表和 department 表之间的参照完整性时,将自动为我们创建该列。
现在,我们将建立 employee 表(外键:workdept)和 department 表(主键:deptno)之间的参照完整性。可以通过创建这两个表之间的“identifying”关系来完成:
从工具箱的 data modeler 列表中选择 identifying relationship 选项,然后先单击 diagram 视图上的父表 department 组件,再单击子表 employee 组件。
图 12. 设置参照完整性
在 relationship specification 对话框中,您可以指定子角色和父角色。
图 13. 关系的具体指定
在 relationship specification 对话框的 migrated keys 选项卡中,您还可以修改 employee 表中的外键列名称:
图 14. migrated keys
您将看到 employee 表中添加了一个新的列。在 table specification 对话框的 column 选项卡中,您可以修改“workdept”列在 employee 表中的位置,如下面 图 15 所示:
图 15. table specification 对话框
您的模型应该与下面 图 16 所示相类似:
图 16. 模型
视图
rational xde 允许您基于表或 sql 查询来创建视图。这些查询可以包括 where、group by 或 order by 子句。您既可以手工为视图指定 sql 查询,也可以在 view specification 对话框中为视图选择各个列。
以下是创建视图组件的步骤:
在 model explorer 中,右击模型后单击 add data modeler -> view。一个新的视图将显示在 model explorer 中。 右击这个新的视图,然后单击 data modeler > open specification。这将打开 view specification 对话框。 在 general 选项卡中,在 name 框中输入“emp_view”作为视图名称。 单击 ok 并将该视图组件拖放至 diagram 视图上。
为该视图指定列:
从工具箱的 data modeler 列表中选择 view dependency,然后先单击图(diagram)上的 view 组件(emp_view),再单击源表组件(employee 表)。
图 17. 创建视图
源表中的所有列都将填充到您的视图中。 此时,您可以通过启用 view specification 对话框的 general 选项卡中的“user defined”复选框,为视图指定定制的 sql 查询:
图 18. 视图的具体指定
然后在同一对话框的 sql 选项卡中输入定制的 sql 查询。完成后单击 ok。
图 19. 视图的具体指定
存储过程
rational xde 还允许您为数据库建立存储过程的模型。所支持的 dbms 有:
ibm db2 udb 5.2、6.1、7.0 和 8.0 ibm db2 mvs 5.x、6.x 和 7.x oracle 7.3、8.x、和 9i for windows nt microsoft sql server 6.5、7.0 和 2000 sybase adaptive server 12.x
在 rational xde 中,术语“存储过程”包括常规的存储过程(返回多个结果)和存储函数(返回标量值)。这两种存储过程都可以用相应的参数和一个动作体(action body)来进行定义和建模。
可是,请牢记数据库和存储过程之间必须存在 实现关系(realization relationship),才能对目标数据库执行 ddl。在 rational xde 中,存储过程在存储过程容器中被分组。在为该模型生成 ddl 之前,需要通过实现关系将表、存储过程和视图指派给该数据库。
创建存储过程组件的步骤:
在 model explorer 窗口中,右击 main。 选择 add data modeler 并单击 stored procedure container。这将在数据模型中创建一个默认名为“procedurecontainer1”的存储过程容器。 您可以使用该容器默认的名称,也可以通过位于 model explorer 窗口之下的 properties 窗口修改它。 右击存储过程容器“procedurecontainer1”,然后,选择 add data modeler 并单击 stored procedure。这将添加默认名为“procedure1”的存储过程容器。同样地,您可以使用这个默认名称,如果希望,也可以通过 model explorer 窗口之下的 properties 窗口来提供另一名称。 您还必须添加从数据库到存储过程的“数据库实现”关系,用以为该存储过程生成 ddl。 为了添加“数据库实现”关系,单击工具箱中的 data modeler,下滚该列表至“database realization”,单击选择它。 然后,先单击数据库组件,接着再单击存储过程容器组件以创建实现关系。该数据模型将如下面 图 20 所示:
图 20. 展示了实现关系的数据模型
此时或稍后,可以通过右击 model explorer 中的存储过程,选择 data modeler 并单击 open specification,来修改存储过程的名称和签名(参数等等)。 这将打开 stored procedure specification 对话框。 在该对话框中,您可以通过 general 选项卡修改过程名、编写语言等,通过 parameters 选项卡添加参数,以及最后通过 action body 选项卡指定一个动作体,如下面图 21 所示:
图 21. 存储过程的具体指定
触发器
xde 允许您创建用户定义的触发器,用以在数据库中实施业务规则。
为触发器建模:
在 model explorer 中右击所需的表。 选择 data modeler 并单击 open specification 以打开该表的具体指定(specification)。 在 specification 对话框中,单击 triggers 选项卡,然后单击 new,为该表建立一个新的触发器模型。 您可以创建一个“after”或“before”触发器,以及为该触发器创建一个动作体。下面的 图 22 说明了是如何进行的:
图 22. 创建触发器
基于数据模型生成 ddl 脚本
rational xde 提供了 forward engineering 向导,用以为整个数据库或数据模型中的指定组件生成数据定义语言(ddl)脚本。rational xde 生成的 ddl 遵循 ansi sql 92 标准。xde 还允许您对目标数据库执行所生成的 ddl,而目标数据库是您在启动数据模型项目之前指定的。因此,要确保您已经正确连接了该目标数据库。同时,该数据模型中的所有数据库组件都必须利用前面小节中所阐明的关系连接该数据库组件。如果没有为任何组件进行该工作,那么就不会为特定的组件生成 ddl。
为了生成 ddl 脚本:
在 model explorer 中,右击一个现有的数据库、包或表,然后单击 data modeler > forward engineer。这将打开用于数据建模的 forward engineering wizard 对话框。然后按照该向导中的指示进行。下面的图 23 是通过 forward engineering 向导为整个数据库生成 ddl 的屏幕快照:
图 23. forward engineering 向导
连接数据库
rational xde 允许您连接一个 dbms,并且执行所生成的 ddl 以创建数据库对象。所支持的 dbms 有:
ibm db2 udb 5.2、6.1、7.0 和 8.0 ibm db2 mvs 5.x、6.x 和 7.x oracle 7.3、8.x 和 9i for windows nt microsoft sql server 6.5、7.0 和 2000 sybase adaptive server 12.x rational xde 支持下列用以连接以上数据库系统的驱动程序:
ibm db2 app driver(odbc) ibm db2 udb jdbc driver oracle ole db provider oracle thin jdbc driver ole db provider ms ole db for odbc ms ole db for oracle(mdac) ms sql ole db provider sybase ase odbc driver为了连接目标数据库,您必须将之配置成 odbc 数据源,并提供正确的访问信息以便能够连接它。既可以将该数据库配置为系统 odbc 数据源,也可以配置为用户 odbc 数据源。您既可以通过 forward engineering 或 reverse engineering 向导建立连接,也可以在比较和同步(compare and sync)模式[rlk1]下进行。还请注意,如果选择连接数据库,您可能需要为所选择的数据库系统安装运行时客户机(对于 db2 udb)或等效的客户机组件(对于其他的 dbms)。关于这方面的更多信息,请查看 rational xde 帮助。可以测试到目标数据库的连接,例如在 forward engineering 向导中通过 execute 复选框进行,如下面的图 24 所示:
图 24. 连接数据库
逆向工程
我们已经介绍了正向工程(forward engineering)。通过逆向工程(reverse engineering),我们可以为已经存在的数据库建立模型。这将允许我们修改该模型,例如添加表、存储过程、触发器等,然后通过生成和执行被修改模型的 ddl 来进行正向工程(forward engineer)。
对数据库进行逆向工程:
在 model explorer 中,右击该数据模型并单击 data modeler -> reverse engineer。这将打开 reverse engineering 向导。 按照向导中的指示选择数据库以及逆向工程过程中所包含的所有元素。
比较和同步模式
rational xde 中的比较和同步(compare and sync)功能用于确保数据模型与所生成的 ddl 或目标数据库一致。比较和同步不包括图和比较模型之间的关系。在比较数据模型和数据库以及使之同步之前,请验证已经正确连接数据库,并且正确登录,口令无误。
将数据模型与 ddl 文件或数据库进行比较并使之同步
在 model explorer 或图中,右击一个现有的数据库,然后单击 data modeler > compare and sync。 这将打开数据模型的 database synchronization wizard。按照向导中的指示进行。 关于比较和同步功能,要记住以下几点: 如果将逆向工程所生成的数据模型与 ddl 进行比较,您就必须将 owner/schema 属性重新设置为您进行逆向工程的模式名。对于比较中包含的每个数据模型元素,您都必须完成该设置。 您应将需要在比较和同步中包含的所有元素指派给数据模型数据库。在比较过程中,xde 会忽略所有未指派给数据模型数据库的元素。 您的数据模型数据库必须使用与所比较的 ddl 或 dbms 数据库相同的名称和目标数据库。 如果将您数据模型中的视图和 ddl 中的视图进行比较,ddl 就必须使用全限定名,尤其是在该视图的 sql 语句中。如果该 ddl 未使用全限定名,那么这些视图在比较过程中看起来就不同,而您就必须手工查看每个视图的 sql 语句,以发现真正的语法差别。
结束语
最后,下面的 图 25 展示了我们的测试项目“data model1”现在的数据库模型。
图 25. 数据库模型
最后,我们概述了使用 rational xde 进行数据库建模的过程,但没有讨论太多细节,以免使初级用户无法承受。这个简单示例已经为您开了个头,您可以开始使用该工具来满足您自己的数据库设计和建模需求。要获得该产品的更多信息,请从 help 菜单查看 rational xde 的在线帮助。
注意
forward engineering 向导未在 ddl 文件中插入或生成数据库 ddl(create database 命令)。这意味着在对目标数据库执行 ddl 脚本之前,需要手工创建目标数据库。 本文采用的 rational xde 版本为 2003.06.00。在建立存储过程模型时,您可能会发现如果在存储过程具体指定的 action body 选项卡中指定了一个动作体,该存储过程的 ddl 中却没有这个动作体。该缺陷在 2004 年 4 月 9 日发布的 service release 2(fixpack 2)中得到了修复。关于当前修正版的更多信息,请查看 www.rational.com。 在为 db2 存储过程指定动作体时,必须使用非传统的 sql 语句终止字符,例如“@”等,因为分号在存储过程体中用于终止存储过程动作语句。然而,在通过 forward engineering 向导生成存储过程 ddl 时,会在“@”后面额外生成一个分号,所以“@”是不需要的,否则 db2 的 sql 编译器会发出错误。 可能需要编辑所生成的 ddl 脚本,以确保所使用的语句终止字符是正确的。
到页首
resources
subgroup of resourcesexplanation of what the resources will provide for the developer. and then list the resources: title of resource title of resource –>
关于作者
suita gupta 是 websphere competency center 小组的技术支持代表。她具有应用程序开发和管理方面的 db2 认证。在 websphere 支持小组工作之前,她在 developer relations db2 technical support 小组中研究各种 db2 应用程序的开发和管理问题。您可以通过 suitag@my.ibm.com 与 suita 联系。
nanda pilaka 是德克萨斯州达拉斯 content manager business partner support 小组的软件工程师。他具有应用程序开发和管理方面的 db2 认证。在 content manager 支持小组工作之前,他在 ibm 达拉斯的 developer relations db2 technical support 小组中研究各种 db2 应用程序的开发和管理问题。您可以通过 nandap@us.ibm.com 与 nanda 联系。