Forward and Reverse Engineering Models and Working with Logical Model Diagrams, Displays and Subviews

Purpose

This tutorial shows you how to work with Logical Model Diagrams, Displays and Subviews with Oracle SQL Developer Data Modeler. In addition, forward and reverse engineering will also be discussed.

Time to Complete

Approximately 30 minutes

Overview

Oracle SQL Developer Data Modeler offers a full spectrum of data and database modeling tools and utilities, including Entity Relationship modeling, Relational (Schema), Data Types or Object Types modeling, and Multidimensional modeling and DDL generation. It includes importing from and exporting to a variety of sources and targets, provides a variety of formatting options and validates the models through a predefined set of Design Rules.

Oracle SQL Developer Data Modeler will be released as an extension to SQL Developer and as a standalone product, for those developers who only want to work with visual data modeling.

In this tutorial, you import a schema from the DB catalog, reverse engineer the relational model to create a logical model, create a subview and display, create two subtypes for an entity, forward engineer to a new relational, create a type and associate the new type with a table and then reverse engineer the modified table to synchronize the relational and logical models.

Importing Schema From the Data Dictionary

In this section, you import the HR schema from the Data Dictionary to create a relational model. Perform the following steps:

1 .

Open Oracle SQL Developer Data Modeler from the icon on your desktop. If you performed the previous tutorial, and did not exit Oracle SQL Developer Data Modeling, select File > Close to close the model you previously worked on.

 

2 .

Select File > Import > Data Dictionary.

Show Screenshot for Step

 

3 .

You need to create a database connection. Click Add.

Show Screenshot for Step

 

4 .

Enter the following and click Test Connection.

Connection Name: <your_sid>_system
Username: system
Password: <your password>
Select Save Password check box
Hostname: <your_hostname>
SID:<your_sid>

Show Screenshot for Step

 

5 .

Your connection was successful. Click OK.

Show Screenshot for Step

 

6 .

Click OK again.

Show Screenshot for Step

 

7 .

Select your connection from the list and click Next.

Show Screenshot for Step

 

8 .

Select the check box in front of the HR schema and click Next.

Show Screenshot for Step

 

9 .

Under the Tables tab, click the Select All icon.

Show Screenshot for Step

 

10 .

Click Next.

Show Screenshot for Step

Click Finish.

Show Screenshot for Step

 

11 .

Review the log. Click Close when done.

Show Screenshot for Step

 

12 .

The relational model is created successfully. In the next section, you reverse engineer to create the logical model.

Show Screenshot for Step

 

Reverse Engineering a Relational Model to Logical Model

In this section, you reverse engineer the relational model to create a logical model. Perform the following steps:

1 .

Select the Engineer to Logical Model icon. An engineering window opens.

Show Screenshot for Step

 

2 .

The warning icons indicate that objects are different between the relational and logical model. Expand the Tables object.

Show Screenshot for Step


3 .

The plus sign icon indicates that the tables will be added to the logical model. Click Engineer.

Show Screenshot for Step

 

4 .

The logical model is created successfully. In the next section, you create a subview that contains only the entities related to the employees table.

Show Screenshot for Step

 

Creating a SubView

In this section, you create a subview for the logical model based on the entities related to the employees table. Perform the following steps:

1 .

Right-click the background of the diagram. There are 3 different notations you can use. In this tutorial, you select Bachman Notation. Note that the Barker notation is used by default.

Show Screenshot for Step

 

2 .

The Bachman notation is now used.

Show Screenshot for Step

 

3 .

Right-click the employees entity and select Select Neighbors.

Show Screenshot for Step

 

4 .

Accept the default of 1 zone and click OK.

Show Screenshot for Step

 

5 .

Notice that the entities related to the employees table are selected. Right-click the EMPLOYEES entity again and select Create SubView from selected.

Show Screenshot for Step

 

6 .

A subview of just the entities selected is created.

Show Screenshot for Step

 

Manipulating Different Displays

In this section, you create 2 different displays of the subview you just created. A display allows you to change the way the diagram looks based on the same set of Logical or Relational Model objects. Perform the following steps:

1 .

Right-click the white space on the subview and select Create Display.

Show Screenshot for Step

 

2 .

You can minimize the amount of detail in the diagram. Right-click the white space in the diagram (make sure your cursor is not on an object) and select View Details > Names Only.

Show Screenshot for Step

 

3 .

Only the Entity Names are displayed.

Show Screenshot for Step

 

4 .

Reduce the size of one of the entities by selecting the entity and dragging the corner so that the entity is a smaller size.

Show Screenshot for Step

 

5 .

Shift-select each entity on the diagram. Select Edit > Equal Width.

Show Screenshot for Step

 

6 .

Notice that all the entities have now the same width on the diagram. The width you obtain is based on the width of the first object you selected. Select Edit > Equal Height.

Show Screenshot for Step

 

7 .

All the entities are now of equal width and height. Again, the height you obtain is based on the height of the first object you selected. You can also redraw the lines manually. Right-click the white space of the diagram and select Auto Route to deselect it.

Show Screenshot for Step

 

8 .

Move the entities to maximize space and redraw the lines.

Show Screenshot for Step

 

9 .

There may be some lines you want to manipulate manually instead of them being redrawn automatically. To manually adjust the lines, you need to turn Auto Route off. Right-click the white space in the diagram and select Auto Route.

Show Screenshot for Step

 

10 .

If you want to move a line to another edge of the entity, select the line. Select the square in the middle of the line. This is called an Elbow.

Show Screenshot for Step

 

11 .

Drag the Elbow to the desired location and release

Show Screenshot for Step

 

12 .

In this example, you also want to drag the other elbow to another location.

Show Screenshot for Step

 

13 .

The screenshot below is the result of moving entities and lines around to maximize space.

Show Screenshot for Step

 

14 .

You can create another display that looks different. Right-click the Logical - SubView 1 and select Create Display.

Show Screenshot for Step

 

15 .

Right-click the white space of the diagram and select Barker Notation.

Show Screenshot for Step

 

16 .

Right-click the white space and select View Details > All Details.

Show Screenshot for Step

 

17 .

The details are displayed for each entity using the Barker Notation. Make the entities bigger so you can see all the attributes and redraw the lines so that they are straight and minimize intersection.

Show Screenshot for Step

 

18 .

In the Browser tree, expand Logical > SubViews > Logical - SubView_1 > Displays. Double-click Display_1.

Show Screenshot for Step

 

19 .

Change the name of the display to Bachman - Names only and click OK.

Show Screenshot for Step

 

20 .

Double-click Display_2. Change the name of the display to Barker - All Details and click OK.

Show Screenshot for Step

 

21 .

Your display names have changed. In the next section, you create 2 subtypes for the EMPLOYEES entity.

Show Screenshot for Step

 

Adding Two Subtypes to an Entity

In this section, you add 2 subtypes to the EMPLOYEES (supertype entity). Perform the following steps:

1 .

From the Barker - All Details Display, select the Create Entity icon.

Show Screenshot for Step

 

2 .

Select anywhere in the white space of the diagram. Enter Sales for the Name and select EMPLOYEES for Super Type. Then select Attributes from the left navigator.

Show Screenshot for Step

 

3 .

Select the Add Attribute icon.

Show Screenshot for Step

 

4 .

Enter Commission Percent for the Name and click Logical for Datatype. Select NUMERIC from the Type drop list, enter 2 for Precision and 2 for Scale. Click OK to create the subtype.

Show Screenshot for Step

 

5 .

Notice that the SALES subtype entity sits inside the the super type EMPLOYEES entity box. The default is the Box-in-Box Presentation.

Show Screenshot for Step

 

6 .

You may need to enlarge the EMPLOYEES supertype entity and reduce the size of the SALES subtype entity.

Show Screenshot for Step

 

7 .

You want to create a relation between the supertype EMPLOYEES and the subtype Sales to store the Account Manager. Select the 1:N relation icon.

Show Screenshot for Step

 

8 .

First select the EMPLOYEES entity.

Show Screenshot for Step

 

9 .

Then select the Sales subtype.

Show Screenshot for Step

 

10 .

A new relation will be created between the EMPLOYEES Supertype and Sales Subtype. Click OK.

Show Screenshot for Step

 

11 .

You can move the subtype and relation so that it is presented optimally. Now that you have created the relation between EMPLOYEES and Sales, you want to rename the relation to Account Manager. Double-click the Sales subtype.

Show Screenshot for Step

 

12 .

Select Attributes in the left navigator.

Show Screenshot for Step

 

13 .

Select the EMPLOYEE_ID attribute from the list. Notice that EMPLOYEE_ID is listed as a foreign key attribute. You can't change the name without changing a preference setting first. Click Cancel.

Show Screenshot for Step

 

14 .

Select Tools > Preferences.

Show Screenshot for Step

 

15 .

Expand Model and select Logical. Deselect the Keep as the name of the Originating attribute option and click OK.

Show Screenshot for Step

 

16 .

Double-click the Sales subtype again.

Show Screenshot for Step

 

17 .

Select Attributes from the left navigator.

Show Screenshot for Step

 

18 .

Select the EMPLOYEE_ID attribute from the list. Change EMPLOYEE_ID to Account Manager and click OK.

Show Screenshot for Step

 

19 .

You want to create one more subtype called Non-Sales. Select the New Entity icon and click in the white space on the diagram.

Show Screenshot for Step

 

20 .

Enter Non-Sales for the Name, select EMPLOYEES for the Supertype and click Attributes in the left navigator.

Show Screenshot for Step

 

21 .

Select the Add Attribute icon.

Show Screenshot for Step

 

22 .

Enter Bonus Amount for the Name and select the Logical Datatype. Select NUMERIC from the Logical Type drop list and enter 10 for Precision and 2 for Scale and click OK.

Show Screenshot for Step

 

23 .

Your Non-Sales subtype was created successfully. You can can resize and move the subtype so that they align correctly in the EMPLOYEES subtype box. In the next section, you forward engineer to a new relational model.

Show Screenshot for Step

 

Forward Engineering to a New Relational Model

In this section, you forward engineer your logical SubView to a new relational model. Perform the following steps:

1 .

You first need to create a new relational model to forward engineer your subview into. In the left navigator, right-click Relational Models and select New Relational Model.

Show Screenshot for Step

 

2 .

The relational model Relational_2 was created successfully.

Show Screenshot for Step

 

3 .

To view the forward engineering strategy for the EMPLOYEES Supertype and its subtypes, select Logical-SubView_1 tab and double-click the EMPLOYEES super type entity.

Show Screenshot for Step

 

4 .

Review the list under FWD Engineer Strategy. Notice that this field is currently set to Single Table which means that all the attributes from supertype and both subtypes will engineer to one table in the relational model. Leave this setting.

Show Screenshot for Step

 

5 .

Click Attributes in the left navigator.

Show Screenshot for Step

 

6 .

Select the COMMISSION_PCT attribute and click the Remove icon.

Show Screenshot for Step

 

7 .

Click OK.

Show Screenshot for Step

 

8 .

Now you are ready to create the relational model. Select the Engineer to Relational Model icon.

Show Screenshot for Step

 

9 .

On the left drop down, select Logical - SubView_1. On the right drop down, select Relational_2. You can expand the tree on either side to view how the model will engineer and what objects will be impacted. When done, click Engineer.

Show Screenshot for Step

 

10 .

Your SubView of the Logical model was engineered and the results are displayed. Notice that the attributes from the subtype entities appear in the EMPLOYEES table in the relational model. You want to change the names of the columns that were added. Double-click the EMPLOYEES table.

Show Screenshot for Step

 

11 .

Click Columns in the left navigator.

Show Screenshot for Step

 

12 .

Change the names as follows and click OK.

Attribute Column
Commission Percent COMMISSION_PCT
Account Manager ACCOUNT_MGR
Bonus Amount BONUS_AMT

Show Screenshot for Step

 

13 .

Your changes were made successfully. In the next section, you create a Type for Employee Address.

Show Screenshot for Step

 

Adding a New Type

In this section, you create a new Type for emp_address_typ. Perform the following steps:

1 .

You want to show the data type model. In the left navigator, right-click DataTypes and select Show.

Show Screenshot for Step

 

2 .

Select the New Structured Type icon and click the white space on the diagram.

Show Screenshot for Step

 

3 .

Enter emp_address_typ for the Name and click Attributes in the left navigator.

Show Screenshot for Step

 

4 .

Click the Add icon.

Show Screenshot for Step

 

5 .

Enter street for Name and select Logical for Datatype. Select VARCHAR for Type, enter 40 for Size. You want to create another attribute. Click the Add icon.

Show Screenshot for Step

 

6 .

Enter city for Name and select Logical for Datatype. Select VARCHAR for Type, enter 30 for Size. You want to create 2 more attributes. Click the Add icon.

Show Screenshot for Step

 

7 .

Create 2 more attributes using the previous steps, then click OK.

Attribute Datatype
state CHAR(2)
postal_code VARCHAR(10)

Show Screenshot for Step

 

8 .

Your datatype is displayed. You want to assign this datatype to a new column in the EMPLOYEES table. Click the Relational_2 tab.

Show Screenshot for Step

 

9 .

Double-click the EMPLOYEES table.

Show Screenshot for Step

 

10 .

Select Columns in the left navigator.

Show Screenshot for Step

 

11 .

Click the Add column icon.

Show Screenshot for Step

 

12 .

Enter Address for the Name. Click the Structured datatype select emp_addtress_typ from the drop-down list.

Show Screenshot for Step

 

13 .

Click OK.

Show Screenshot for Step

 

14 .

Your table has been updated with a new column that uses the emp_address_typ. In the next section, you reverse engineer (engineer to logical model) the Address column to the super type entity EMPLOYEES.

Show Screenshot for Step

 

Synchronizing Relational and Logical Models

In this section, you engineer the column you added in the EMPLOYEES table to the super type entity in the Logical Model. Perform the following steps:

1 .

With the Relational_2 tab selected, click the Engineer to Logical Model icon.

Show Screenshot for Step

 

2 .

Under Relational_2, expand Tables mapped to Hierarchies. Expand the second EMPLOYEES node and its columns in the list. This node corresponds to the Sales subtype in the Logical Model. You do not want the Address column added to the Sales subtype. Make sure the check box in front of Address is not checked.

Show Screenshot for Step

 

3 .

Expand the EMPLOYEES node that corresponds with the Non-Sales entity and its columns in the Logical model. You do not want Address to be added to the Non-Sales subtype. Make sure the check box in front of Address is not checked.

Show Screenshot for Step

 

4 .

Scroll up the list and expand the first EMPLOYEES node to see that the Address column will be added to the super type. Make sure the the check box in front of Address is checked. Then click Engineer.

Show Screenshot for Step

 

5 .

The Logical Model is displayed. Click the Logical - SubView_1 tab.

Show Screenshot for Step

 

6 .

Notice that the Address column was added to the EMPLOYEES super type. It was not added to the Sales or Non-Sales subtypes.

Show Screenshot for Step

 

Summary

In this tutorial, you have learned how to:

Hardware and Software Engineered to Work Together About Oracle |Oracle and Sun | Oracle RSS Feeds | Careers | Contact Us | Site Maps | Legal Notices | Terms of Use | Your Privacy Rights