Collection Contents Index What you can do with SQL Modeler What else you can do with SQL Modeler pdf/chap9.pdf

First Guide to SQL Anywhere Studio
   PART 2. Getting Results with SQL Anywhere Studio
     CHAPTER 9. Designing Databases with SQL Modeler       

Example: Modifying a database


SQL Modeler can read the structure of a database from a script file that creates the database. However, it's generally easier to just connect to your database from SQL Modeler and let it extract the design directly.

The following tutorial uses the sample database as a starting point. Three modifications improve the design.

  1. The price of each product is always read from the product table. As a result, updating the price effectively changes the sale price of that item on all previous orders.

    Adding a unit_price column to the sales_order_items table corrects this problem. The actual selling price to each customer can now be stored separately. The price in the product table records the current list price.

  2. Soon, expansion of the company will mean that some employees must work out of other offices. A new office table is added to contain information specific to a particular office, such as its address and central phone and fax numbers.

  3. To facilitate the use of key joins, a reflexive manager reference is associated with the employee table.

The following tutorial shows you how to make all three of these modifications. In doing so, it introduces many of the basic elements of SQL Modeler.

  Start SQL Modeler:
  1. From the Start menu, select Programs-> Sybase ->->SQL Modeler 6.1->SQL Modeler.

    Initially, the SQL Modeler window will appear similar to that shown below.

  2. Select the database name Sybase AS Anywhere 6 from the list of Sybase database products.

    SQL Modeler needs to know which database you are building to customize options and to generate compatible SQL scripts. You can switch to another product later and generate a database for the new product.

SQL Modeler can reverse-engineer a database through and ODBC connection. If you are reverse-engineering your own database, you need to create a data source.

The setup program creates a data source for the sample database during installation. This data source is called ASA 6.0 Sample. If it is absent, you will need to create and configure another data source.

  Check or add the ODBC data source:
  1. From the Start menu, select Programs->Sybase->Adaptive Server Anywhere 6.0->ODBC Administrator.

    For Info    For further information see Using ODBC data sources to connect.

  2. Close the Data Source Administrator when you finish.

  Reverse-Engineer the database:
  1. Connect to the sample database.

  2. Pick the components of the database definition that you would like your model to contain.

  3. Choose OK to commence reverse engineering.

  4. Examine the diagram before you.

    Each table in your database is represented by a rectangular box. The name of the table appears at the top. Below, is a list of the columns. Column names that are underlined are part of the primary key for that table. The data type of each column appears on the right. Some of the tables may overlap.

    References between tables are represented with arrows. The arrows point toward the parent table, that is the table that contains the primary key. An equation appears next to each arrow that identifies the reference.

  5. You can drag tables, or groups of tables, around using the mouse. The reference arrows follow, automatically.

    One possible arrangement appears below.

Top of page  Change 1: Add a column

You are now ready to make the first of the three changes, namely adding the unit_price column to the sales_order_items table. You can accomplish this task by accessing the list of columns through the table properties dialogue.

  Add a column:
  1. Display the column properties.

  2. Add a new column to hold the unit price.

  3. Examine the effect of your changes on the diagram of the database.

You have now completed the first of the three changes.

Top of page  Change 2: Add a table

The second task is to add a new office table. You can easily do so using the table tool. You then add a reference to connect it to the employee table.

  Add a new table:
  1. Select the table tool. Use it to create a new table near the employee table.

  2. An office has many of the same attributes as a customer or contact. To define the columns of the new table efficiently, first copy the columns of the contact table onto the clipboard using the following steps:

  3. Define the properties of the new table.

  4. Define the columns of the new office table.

  5. Define a check condition for the id column of the new office table.

  6. Complete your changes to the office table. Choose OK to exit each dialogue. Your new table should appear similar to that shown below.

  Add a reference using the reference tool:
  1. Select the reference tool. Use it to create a new table near the employee table.

  2. The column name office_id is probably more appropriate for the employee table. Change the name of the new column to office_id using the column properties. (Remember to de-select the Reference tool, first.)

You have now completed the second of the three changes.

Top of page  Change 3: Add a reference using the Dictionary

While completing the second task, you added a reference using the reference tool. In this portion of the tutorial, you learn another way to add and manipulate references. In so doing, you will discover a very important feature of SQL Modeler, the dictionary.

The Dictionary is a master list of all the objects in your schema. It is very useful both because it lets you see all the objects of each type side-by-side and because you can choose not to display some objects in the diagram. Your only means of accessing such objects is through the Dictionary.

  Add a reference using the Dictionary:
  1. Choose Dictionary->List of References.

  2. Add a new reference. Use ky_manager_id as the name and code. Since this will be a reflexive reference, identify the employee table as both the parent and the child.

  3. Set the referential integrity properties of the new reference.

  4. Display the Referential Integrity dialogue.

  5. Set the cardinality to be 0 to n, an employee may manage any number of other employees, or may manage none.

  6. Set the update and delete constraints to restrict.

  7. Choose OK to close each dialogue.

  8. When you add the reference, SQL Modeler adds a new column named emp_emp_id to the employee table. The name manager_id was previously in use and is much better.

  9. Display the properties.

  10. Delete the manager_id column.

  11. Rename the new column manager_id. Update the code, too.

  12. Choose OK to close each dialogue.

    Notice that SQL Modeler updates the condition on the new reference automatically.

You have now completed the third of the three changes.

Top of page  Check your work

A big advantage of SQL Modeler is that you can quickly detect many errors simply by examining your new diagram.

  Check your new schema:
  1. Check your new model using the diagram. Your new database should appear similar to the diagram shown below.

  2. Ask SQL Modeler to check your model.

Top of page  Save your changes and generate the new database

Models that depict the physical components of your database design, including tables and columns, are called physical data model (PDM). SQL Modeler stores these in files with the suffix .PDM.

  Save the physical definition file (PDF):
  1. Choose File->Save As. Save your physical data model in a convenient location.

An easy way to create a database using your new design is through means of a SQL script that implements all the components of your model.

  Generate a SQL script to create your new database:
  1. Generate a SQL script.

  2. View the new script.

You can create your new database from Interactive SQL.

  Create the new database:
  1. Start Interactive SQL.

  2. Connect to the sample database. You can use the same ODBC connection.

  3. Create an empty database.

  4. Close the connection to the sample database.

  5. Connect to the new database.

  6. Execute the script.

You use these basic steps to modify other databases.

Top of page  

Collection Contents Index What you can do with SQL Modeler What else you can do with SQL Modeler pdf/chap9.pdf