Presentation on theme: "AN INTRODUCTION DB-Examiner Version 2008 - January 2008."— Presentation transcript:
AN INTRODUCTION DB-Examiner Version 2008 - January 2008
This document serves two purposes: If a copy of DB-Examiner is installed, it is a script for demonstration of some of the important features of the product. If DB-Examiner is not yet installed, this document introduces the reader to the usability, usefulness and unique advantages of DB- Examiner, convincing reasons to install and evaluate the product. An Introduction to DB-Examiner
What is DB-Examiner DB-Examiner is a tool to debug the database schema, in its several stages of development: - as a data model; - a set of SQL/DDL scripts, or; - the database schema itself. It is well known that a flawed schema is the main reason why applications: - take so long to develop; - cost so much; - do not run at peak, and; - produce poor information. By debugging the schema, these issues will be minimized.
Preparation Initially, set DB-Examiner to ONLY process Defined FKs. Go to Tools > Preferences > General Settings TAB and set the Implied Relationships Procession option to None (which means Do not imply any relationships – use the defined Foreign Keys Only).
Sources of INPUT to DB-Examiner DB-Examiner can read a model from 3 different sources: From an ERwin V7 model (.erwin file); From a set of DDL scripts (eventually created by another modeling tool); From the Database itself (dictionary, catalog, system tables).
Reading a Model directly from the Database (1/3) Go to File > New and select the DBMS Schema option. Click the OK button and get the Dialog to select the Database Platform.
Reading a Model directly from the Database (2/3) Select Oracle (or any database that you have) and click OK.
Reading a Model directly from the Database (3/3) Click the Connect button and get the list of Owners. Select the Owner that has the database that you want to analyze and click OK. The model will be read from the database.
Reading a model from DDL scripts (1/3) Go to File > New and select the SQL/DDL Script option.
Reading a model from DDL scripts (2/3) Click OK and then select the type of script (in this case SQL Server).
Reading a model from DDL scripts (3/3) Select the DDL file that you want to analyze (SQLDemo.txt or DEMO.txt – they are the same). Click OK and the model will be read for the DDL script.
Reading from an ERwin Model (.erwin file) (1/2) Go to File > New and select Data Model from Erwin or Data Model from Model Manager.
Reading from an ERwin Model (.erwin file) (1/2) Click OK and get the Open Model Dialog. Select the ERwin file you want and click Open. The model will be read directly from the ERwin File.
Analyzing the Model (1/2) For the purpose of the demo we shall use a SQL Server DDL script – DEMO.txt. Select the model as described in example Reading a model from DDL scripts. At the following screen, ensure all tables are selected then click OK.
Analyzing the Model (2/2) Once the model is opened, you will see: You can see that the model was processed in DB- Examiner with Foreign Keys Only (NO Implied Relationships option). You can also see that the model has 12 tables. Number of tables Name of model Foreign Keys Only
Tables If you want you can open the branches of the tables and check the details of each table. You can drill-down as long as there is a + sign.
Relationships Click on the Relationships TAB and you will see the number of relationships (5) that have been defined. Defined Relationships
Changing the Relationships Option to ALL (1/2) Let us now go to Tools > Preferences and set in the General Settings TAB, the option Implied Relationships Processing to ALL. Click OK or Apply. DB- Examiner will reprocess the model, now trying to infer additional relationships that the user may have forgotten to define.
Changing the Relationships Option to ALL (2/2) If you click on the Relationships TAB, you will see: You can see now that we have many more relationships (14) than before (5).
Implied Relationships Let us open one of these relationships. Click on the + sign in front of the Table EMPLOYEE. You can see that Table EMPLOYEE (as a Parent) has 2 relationships: a) one Defined (the Red R indicates the On Delete Restrict rule for the FK) with table EMPLOYEE itself, and; b) one Implied (the green I indicates Implied relationship) with table SALESMAN as a child.
Details of the Relationships (1/4) Before opening the relationships, let us do the following to simplify the viewing: Right-Click on the Model Name (Demo) on the tree to see the options available. Then unselect the option Cascade Relationships. By doing this, DB-Examiner will only show the first level of relationship. If you want to see all levels, then leave the option selected.
Details of the Relationships (2/4) Open the two relationships, clicking in every + sign. You will see this:
Details of the Relationships (3/4) You can also see the PK and the FK or Implied FK of each relationship. We have a real FK from MANAGER_ID in Table EMPLOYEE to the PK (EMPLOYEE_ID) of table EMPLOYEE. This is a recursive relationship. DB-Examiner inferred a relationship between EMPLOYEE as a Parent to SALESMAN as a Child because the PK of EMPLOYEE is EMPLOYEE_ID and in table SALESMAN we also find EMPLOYEE_ID as a non-key attribute. This means that possibly there is a One- to-Many relationship from EMPLOYEE to SALESMAN. It is up to the user to confirm (do nothing) or delete this relationship.
Details of the Relationships (4/4) Note the other options: Show Relationship Component – to display the PK and the FK or Implied FK of the Relationship. Cascade Relationships – With this un-checked, DB-Examiner will only show one level of relationships; otherwise it will show all levels. This relationship tree shows the relationships from the Parent to the Child. If you want to see the relationships from the Child to the Parent, just right-click on the Model Name on the tree and select View Child to Parent.
Diagnostics (1/3) The user can customize the Diagnostics by going to Tools > Preferences > Diagnostics Settings > Select Individual Diagnostics. For each Category, the user can select the diagnostics to be executed and assign a severity level to each diagnostic. Then the user can save the selected set of diagnostics and can use this set to perform the analysis. Click the Diagnostics TAB; you will see the following screen:
Diagnostics (2/3) This means that the diagnostics have not been performed. Double-Click on the Model Name to perform all diagnostics. Then collapse all the branches and you will see:
Diagnostics (3/3) You can see that this model has a total of 50 diagnostic messages, where 2 are in the Columns category, 28 in the Index and Constraints category, 6 in the Normalization category and 14 in the Relationships category. The diagnostics can be shown by Category or by Severity Level. To change right-click on the top of the diagnostics tree and select the appropriate option: Order by Severity or Order by Category. Later you will see the Reports; they will be sorted by Category or Severity according to the selection made here at the Diagnostics TAB.
Columns Diagnostics If you expand the Columns category, you will see:
Inconsistent Definition (1/3) Let us open the Inconsistent Definition diagnostic. Click on the i button in front of the Inconsistent Definition diagnostic; you will see:
Inconsistent Definition (2/3) This message explains the diagnostic. If you need more details, click the Teach Me button. Click on the + sign. You can see that COMPANY_NAME has 2 different definitions. Let us open COMPANY_NAME to see the different definitions. We can see that COMPANY_NAME is defined with two different Datatypes: a) Char (30) in one table, and; b) Varchar(25) also in one table.
Inconsistent Definition (3/3) If we open both Datatype definitions, we can see where these attributes are located. Now you can see that the attribute COMPANY_NAME in table CUSTOMER is defined as Char(30) and in table ORDER_TBL it is defined as Varchar(25). This is a bad situation and must be fixed by either: a) defining the two occurrences with the same definition, or; b) eliminating the attribute from table ORDER_TBL, or; c) renaming one of the attributes.
Viewing the Model in a Graphical Representation (1/2) Go to View > Graphic to obtain a graphical representation of the data model or schema.
Viewing the Model in a Graphical Representation (2/2) The relationships are represented as a default by Connector Boxes that link any two tables. The diagram can be navigated, by clicking on the link. Those Connector boxes can be transformed into lines, by right- clicking in them. To set Connector Boxes as default, go to Tools > Preferences > Display Settings and select Use Connector Boxes; set the value to ZERO. This means that Connector Boxes will be used for every table in the Diagram. If you set it to 1, it means that Lines will be used for the tables that are next to each other and the rest of the tables will be drawn with Connector Boxes.
Looking at a Table in the Graphical Representation In the example before, let us say that we would like to view the definition of table CUSTOMER to check the definition of attribute CUSTOMER_NAME. Once the model is open in the right side of the screen, we can go to the diagnostics tree and ask for a table to be displayed in the Graphical View. Right-click the CUSTOMER table in the Incorrect Definition diagnostic and select the option Scroll to Table in Model. The table CUSTOMER will be displayed at the top left part of the design on the right side of the screen. This capability will help you debug your model.
Indexes and Constraints Diagnostics Collapse the Column diagnostic and expand the Indexes and Constraints diagnostics.
Incorrectly Defined FK (1/3) Let us click on the information (i) button of the Incorrectly Defined Foreign Key diagnostic. You can see a short explanation of the problem.
Incorrectly Defined FK (2/3) Let us now open this diagnostic by clicking the + sign. Here we see that the table that has a problem is REGION and the FK is FK_REGION_COUNTRY.
Incorrectly Defined FK (3/3) Let us click the i button on the FK_REGION_COUNTRY. Now you can see that we can click three buttons (in addition to the OK button): A) Teach Me – to get additional explanation about the situation or problem; B) Correction – to generate the DDL script to fix a situation; C) Show Me – to isolate the tables involved in the problem.
Teach Me By clicking on the Teach Me button you get: DB-Examiner will explain the problem and the impact on the application if this situation is not fixed.
Correction By clicking on the Correction button, you get: DB-Examiner generates the DDL script to correct the specific situation. DB-Examiner DOES NOT make any changes to the database. The script can be copied and pasted to a file for further processing later.
Script Generation to a File If you want to have all the scripts in a file, go to File > SQL Generation > New File. DB-Examiner will generate a file named with the same name as the model and the extension.SQL.
Show Me The show me button will show in a graphical representation the files involved in the specific situation. Click on the Show Me button and you will see: Now you can understand the problem by looking at the tables that are involved in a specific situation.
Missing Indexes (1/5) Collapse the Incorrectly Defined FK and expand the Missing Indexes diagnostic. Click on the i button.
Missing Indexes (2/5) Click on the + sign. Now you see that there are 8 relationships that do not have any index on the FK attributes. This means that these joins may be slow, depending on the optimizer. Some relations are real (the first and the last one) and the others are implied relations.
Missing Indexes (3/5) Let us open the recursive relationship EMPLOYEE to EMPLOYEE. The FK that is not indexed is FK_EMPLOYEE_EMPLOYEE, based on MANAGER_ID.
Missing Indexes (4/5) In order to fix the problem, we must click the i button in the FK.
Missing Indexes (5/5) Then we must click on the correction button.
Normalization Diagnostics Collapse the Index & Constraints Diagnostics and expand the Normalization Diagnostics. You see that there are 6 messages related to Normalization issues; 1 is called Incorrect Functional Dependency, 2 are related to First Normal Form Deviation, 1 is related to Second Normal Form Deviation and 2 are related to Third Normal Form Deviation.
Second Normal Form Deviation (1/4) Redundancies are called Deviations from the Normal Forms (1st, 2nd, 3rd). It is not bad to have redundancies in your database, but it is very bad if you do not know that you have them or that you do not control them. Thus, detecting the redundancies is a matter of locating the original attribute and the copy (or copies) so you can update the copies when the original is updated. After these are located, you can implement a trigger (or other mechanism) to make sure the information is in synch. First Normal Form Deviation is bad and must be avoid.
Second Normal Form Deviation (2/4) Let us click the Second Normal Form Deviation. Here we can see that the attribute UNIT_PRICE is redundant in tables ITEM_HISTORY and ORDER_ITEM.
Second Normal Form Deviation (3/4) Now if you click on the red i button on the attribute, you will see where the attribute UNIT_PRICE is stored in its original form. Now you can see that when the UNIT_PRICE in table ITEM is updated, you should check whether it is appropriate to update the same attribute in the other tables (ITEM_HISTORY and ORDER_ITEM).
Second Normal Form Deviation (4/4) Click the Show Me button and you will see the tables involved in this diagnostic. Here you can see that DB- Examiner displays a 2 in a red circle before the attribute that is in a Second Normal Form Deviation. Note that: A) First Normal Form is a repeating group; C) Incorrect Functional Dependencies is a redundancy that doesnt fall into these categories. B) Second and Third Normal Forms Deviations are very similar, depending only on some technical definitions; you can see the difference in the Teach Me for each one;
Relationship Diagnostics Collapse the Normalization diagnostics and expand the Relationship Diagnostics.
Non Enforceable Relationships (1/4) Expand the Nonenforceable Relationships. Here we can see all the relationships that DB-Examiner inferred. If the user has not deleted them, then DB-Examiner will generate the scripts to enforce them.
Non Enforceable Relationships (2/4) Click on the first one (CUSTOMER/ORDER_TBL). Here you can see that in table ORDER_TBL there is no defined FK. If you want to enforce the relationship, you must generate the DDL scripts to create a FK to table CUSTOMER.
Non Enforceable Relationships (3/4) Click on the red I button in front of the Implied FK.
Non Enforceable Relationships (4/4) Now click on the Correction button. You can see that when this script is applied to the database, the FK will be created.
What If Scenarios DB-Examiner allows the user to play with What If scenarios, with the File > Merge option. After loading a model – let us say from the database – the user may simulate changes to this model by merging a set of DDL Scripts to the model in DB-Examiner. The model is then re-processed with the combination of data from – in this case – the database and the DDL scripts.
Customizing the Model or Schema The user can add information about his model so DB-Examiner will better understand his/her model specifics. This is done using the User Definitions option. The user can provide knowledge to DB-Examiner about his/her model or database schema, in particular about: a) Tables b) Columns c) Relationship Let us examine each option the user has:
Customizing the Model or Schema - Tables Tables – A Table can be qualified as a Work Table or as a Mirror of. Work Table - If a table is used for calculation and is not really an essential part of the database, the user may qualify the table as a Work Table. DB-Examiner will exclude the table from the analysis. Mirror of – Let us look at the table Item_History in the DEMO model. This table contains the history of the prices for each item. DB-Examiner will always list the attribute UNIT_Price as a Second Normal Form Deviation. This is not a real Second Normal Form deviation. To avoid this diagnostic, qualify the table as a Mirror of table Item. This will tell DB-Examiner not to display this diagnostic. There are several ways to qualify a Table. The easiest is to go to the Tables tree, select the table you want to qualify, right-click and select the type of qualification you want.
Customizing the Model or Schema - Columns Columns – a Column (attribute or field) can be qualified as: Log, Code, Homonym or Synonym. Log – is used to indicate that the attribute (field) is used for logging purposes. Let us say that you may have in all the tables an attribute called Date_Created. You do not want DB-Examiner to analyze this attribute in every table. By qualifying the attribute as LOG, it will be excluded from the analysis. Code – If you have a First Normal Form deviation that is not really serious, such as Telephone1, Telephone2, Telephone3, you may qualify them as CODE and DB-Examiner will not display the diagnostic.
Customizing the Model or Schema - Columns Homonym – If you have an attribute called Name in several tables such as Employee, Company, etc, you do not want DB- Examiner to analyze this attribute because in reality they probably will refer to different data and have different data definitions. The ideal would be to change these occurrences to EmployeeName and CompanyName but, if you cannot do that, just qualify the column Name as a Homonym. DB-Examiner will not analyze them. Synonym – If you have attributes such as Client_ID and VIP_Client_ID and they represent the same thing in different tables, you need to tell DB-Examiner that they are Synonyms. To add these qualifications to the knowledge base, select the attribute you need to qualify in the table tree, for example, and right-click. You will see two options: Qualify Column and Define Synonym.
Customizing the Model or Schema - Relationship Relationship – The only qualification for a relationship is to Delete the Implied relationship. If the user does not accept the relationship discovered by DB-Examiner he may qualify it as Deleted. To do that, go to the Relationship TAB, select the offending implied relationship and right-click on it.
Reports and Listings DB-Examiner has several reports and listings. Go to Reports and select one of the types of reports (Diagnostics, Listings, Model Statistics and Bitmap Legend). These reports can be viewed on the screen, printed or exported to HTML. In the TRIAL version, the reports are disabled and the export facility is also inhibited The Diagnostics reports will be presented according to the Diagnostics tree. If the tree is by Category, the Diagnostics reports will be by category. If the tree is by Severity level, the Diagnostics reports will be by Severity level. The Reports can be viewed in the screen, printed or exported to PDF. In the TRIAL version, the printing is disabled and the export is blocked.
Comments, Suggestions and Doubts We prepared this document to help you better understand DB- Examiner and how to use its features. This document is not exhaustive, but it shows the major features. If you have any questions, comments or suggestions, please send an e-mail to LCS@dbesoftware.com. We will take your suggestions seriously and will incorporate them if they help improve the document.LCS@dbesoftware.com We really appreciate your feedback. Luiz C Siqueira DBE Software +1-703-847-9500 LCS@dbesoftware.com
Acquiring DB-Examiner If you are interested in acquiring DB-Examiner, contact: Europe Tarragon Solutions Ltd Phone: +44-1978-369-146 firstname.lastname@example.org http://www.tarragon.co.uk/dbexaminer Latin America Princeton Systems Computação Ltda. Phone: +55-13-3474-4650 email@example.com http://www.princeton.com.br firstname.lastname@example.org http://www.princeton.com.br Other Countries DBE Software Phone: +1-703-847-9500 email@example.com http://dbesoftware.com