Tool Mentor: Designing Databases
Using Rational XDE Developer - .NET Edition
Purpose
This tool mentor describes how to build a Data
Model with the Data Modeler.
This section provides links to additional information related to this tool
mentor.
The steps in this tool mentor match those in the activity.
Overview
The following steps are performed in this tool mentor:
The Rational XDE software tool includes features that allow the application
designers and database designers to develop the application and the database
using the same tool. As a database
designer or designer,
you can use XDE to model and design databases, as well as to integrate your
application and database. The XDE Data Modeler uses the Unified Modeling
Language (UML) Profile for Database Modeling as the standard notation for constructing
Data Models. The following XDE online Help topics provide key background
information on specific details related to database modeling and development
using Rational XDE:
-
: Lists the databases supported in Rational XDE.
-
: Lists data access providers and drivers supported in Rational XDE.
-
: Summarizes setting the default database assignment and database target.
-
: Provides guidance for configuring XDE Data Models to point toward a specifically
named database.
-
: Summarizes the Unified Modeling Language (UML) modeling elements used in
the Data Model.
-
: Lists notational elements for defining primary/foreign keys and database
triggers specific to a Data Model.
There are three ways to begin a Data
Model in XDE:
- Build the Data Model directly in XDE using the Data Modeler tools.
- Transform persistent classes in the Design
Model to create tables in the Data Model.
- Reverse engineer an existing database schema or DDL script to create a Data
Model.
For more information about the different methods for creating the Data Model,
refer to the following XDE Help topics:
The remaining sections of this tool mentor provide instructions on how to build
a Data Model by transforming persistent classes in the Design Model to develop
it. The Data Model package structure that is discussed here is described in
more detail in the Data Model section of XDE
Model Structure Guidelines.
Tool Mentor: Reverse Engineering Databases Using Rational
XDE provides more information on how to create a Data Model by reverse engineering
the physical database design.
Some projects might need to create a idealized "logical" model of
the database design that captures an application-independent view of the key
logical data entities and their relationships. This Logical Data Model can be
thought of as an "analysis" type of model similar to the optional
Artifact: Analysis Model that
might be used in the development of the application design. It should
be noted that the Logical Data Model is included in the Artifact:
Data Model and is not considered to be a separate RUP artifact.
The Logical Data Model can be created directly using XDE Data Modeler tools. See
the XDE Model Structure Guidelines
for information on creating a Logical Data Model within the overall Data Model
artifact. Refer to the
topic in the Rational XDE online Help for more information on developing the
logical database design.
You can refine the Logical Data Model to create a detailed model of the physical
database design using Rational XDE.
(See
.) This detailed Physical Data Model might then be forward engineered to create
a database. (See Tool Mentor: Forward Engineering Databases
in Rational XDE.) The major steps in developing a Physical Data Model
are described below.
Create domains to implement user-defined data types that can be used throughout
the Data Model to enforce database design standards. (See
.) Domains can also be used to embed business rules in columns.
In order to use the data types defined by the domains in the Data Model, you
must follow these guidelines:
- Domains should be defined in a separate package within the Data Model. For
larger teams, a separate XDE model is often warranted. (See
.)
- The package containing the domains must be assigned to the database component
that realizes the tables in the database. (See
.)
For information on how to apply a domain to a column in the Data Model, see
.
Transform persistent classes in the Design Model into tables within it. (See
.) The attributes of the classes become columns in the tables. Rational
XDE provides the option of defining attributes of the classes as candidate keys.
(See
.) Rational XDE also converts specific associations between the classes to relationships
between the tables. The following Rational XDE online Help topics provide more
information on how the classes are transformed into tables:
- General Mapping Information -
- DBMS Specific Mapping Information -
Create reference tables as needed for managing any static data items in the
database. You can create reference tables directly in the Data Model using
the XDE Data Modeler features. See the
topic in the Rational XDE online Help for general information about creating
tables.
Define primary key constraints and unique key constraints to identify rows
of information in a table. See the online Help topic
for more information on using primary key constraints. The online Help
topic
describes the steps used to create a primary key constraint on one or more columns
of a table. Information on defining unique key constraints is contained
in
, and the steps to create a unique key constraint in the model are described
in
.
Refer to the topic
in the Rational XDE online Help for additional information.
Check constraints can be used to control updates to data elements in tables. Rational
XDE provides the ability to define check constraints for tables, columns, and
domains. See the topic
in the Rational XDE online Help for a description of check constraints. The
following XDE online Help topics describe how to create the three types of check
constraints in the Data Model:
- Column Check Constraints -
- Table Check Constraints -
- Domain Check Constraints -
Another type of constraint used to assure referential integrity is the foreign
key constraint. (See
.) Foreign key constraints can be produced only by creating a relationship
between tables. (See
.) The exception to this is the process of reverse engineering a database
or DDL script into a Data Model, in which case the relationships, and therefore
the foreign keys, are generated automatically. Key migration depends on
the type of relationship identifying versus non-identifying added between two
tables.
Refer to the topics
and
in the Rational XDE online Help for further details on how keys are migrated
as foreign keys.
Depending on the specific project situation, you might need to adjust the normalized
physical database design to meet performance requirements. Optimize the
Data Model for performance improvement by designing the tables to store objects
that are retrieved together in the same table. This technique is called
de-normalization. To de-normalize, combine the unique columns from the
two tables into one, and remove the second table.
An additional optimization technique is to use column indexing to access data
in tables more efficiently. See
for an overview of how to use indexing to improve database performance. See
for a description of how to create indexes in the Data Model.
Another aspect of data access is in the use of database views. Views
can be used to control or restrict access to data in one or more tables. See
for a description of how to create a view in the Data Model. For
more information on views, refer to
.
Create a model storage design for the database by defining the tablespaces
and tablespace containers. (See
.) Map the physical database design elements to the storage elements through
realization relationships. The XDE online Help topic
describes how to create tablespaces for a specific database. The XDE online
Help topic
describes how to assign the tables in the model to the tablespaces.
Rational XDE currently supports modeling tablespaces for Oracle, DB2, and SQL
Server. The following XDE online Help topics provide guidance on how to
model tablespaces for these DBMS products:
Refer to the following topics in the Rational XDE online Help for more information
about tablespace and database model elements:
Define stored procedures as needed to support efficient storage and retrieval
of information in the database. Examine the operations of the design classes
that were used to create the tables for candidate stored procedures. Stored
procedures can be implemented as procedures or functions. See
for a description of stored procedures. Stored procedures must reside in a Stored
Procedure Container, as described in
. Stored procedures are created as operations of the Stored Procedure Container
class in which they reside. See
,
, and
for details on how to create stored procedures using Rational XDE.
For more information on stored procedures, refer to the topic
in the Rational XDE online Help.
Define triggers as needed to further control and manage modifications to the
information in the tables. Refer to the topic
in the Rational XDE online Help for a description of the types of triggers supported
in XDE and for additional topics on how to create triggers in the model.
Review the results of the database design in the Data
Model for consistency with the application design in the
Design Model and with the overall application architecture structure. Refer
to Checkpoints: Data
Model for specific items to review.
|