Administration Component
Compare Objects
The Compare Objects tool is used to compare the definition of objects. It is mainly used to compare the definition of tables, however it has been configured to compare some other types of objects.
You run the Compare Objects tool from the Database Explorer using the compare icon on the Admin Toolbar. You will see this icon only if the Compare Objects function has been configured for your database and object.
The Compare Objects tool is part of the Extended Edition of AQT, which is a separately purchasable component of AQT. If you have not purchased the Extended Edition you can still use Compare Objects, however you will not be able to use the Compare all objects in schema option. Alternatively you may wish to use the "old" compare tables function that was part of AQT v6.
Using Compare Objects
AQT can compare objects other than tables. The description below explains how Compare Objects works for tables.

Compare
This specifies the objects to be compared.
- you can compare either a single object, or all objects in a schema. 
- when comparing all objects in a schema, you can specify a Filter to limit the number of objects compared. 
- if you are running in evaluation mode, you will only be able to compare a single object to another single object. 
- the compare-to object can be in the same or different database to the object being compared. 
What to Compare
The What to Compare box shows you all the components that make up the definition of the table. These are:
- the table attributes (tablespace, pagesize, description etc) 
- the table columns 
- the "related objects" of the table (indexes, primary key, foreign keys etc). 
Select or de-select components to specify what to include in the compare.
Each of these components is defined in AQT as a set of parameters. When you click on one of these components (in the left box) you will be shown these parameters in the Parameter for box:
- if the parameter is checked, AQT will compare that parameter 
- if the parameter is not checked, AQT will not compare that parameter 
- if the parameter has an asterisk * beside the name, the parameter is a compare parameter (this is described later in in How Object Compare works). 
In general you should not change the Parameter compare settings from the default values.
Save / Open options
File > Save Options will save the details of the components and parameters you have selected to be compared. This can be reloaded with File > Open Options.
AQT can remember you options by automatically saving and opening your options. This is done by checking the Automatically Save / Open options option.
Other Options
- For columns, compare by column name. By default, when comparing columns, AQT will compare by column-number (the order it is defined in the table). If you aren't interested in the order of the columns in the table, you can check this option. The columns will then be compared by column name. 
- Ignore case when comparing. When this is checked, AQT will ignore the case when comparing values. De-select this if you want to do case-dependent compares. 
- Ignore schema names when comparing objects. This is a subtle option that is useful in some circumstances. If you are comparing tables in different schemas, the schema names for the tables is ignored. In other words SCHEMA1.TABLE1 will be matched and compared to SCHEMA2.TABLE1. However, the issue arises as to how to treat the "related" objects. If SCHEMA1.TABLE1 has a view SCHEMA1.VIEW01A and SCHEMA2.TABLE2 has a view SCHEMA2.VIEW01A, are these the "same" view that needs to be compared, or are they "different" views? - By default, these will be considered as being different views, so will be flagged as being in one table and not the other. This is an appropriate way for the compare to be done if you are comparing schemas of the same names in different databases. If you are comparing different schemas, you may however want to match on view name only (eg. VIEW01A) and not schema/name. In this case, you should check this option. AQT will regard SCHEMA1.VIEW01A and SCHEMA2.VIEW01A as the same object and will compare these. 
- Automatically Save / Open options. When this is specified: - the compare options are saved to disk whenever you either run a compare or close the window 
- when you open the window, AQT will check whether a saved-options file is present. If so, it will open these options. 
- the options file is compare_<database_type>_<object_type>.txt in your saved-queries directory. This means you will have a different options file per database type and object type. 
 
Report File
AQT can generate a report file that details the differences between the objects. This can be used as a useful summary of the differences.
- Write report file. Specified whether a report file is to be generated 
- report file name. Use this to specify the name of the report file. Click on View to view the report file in Notepad (it can be printed from there). 
- Only report on differences. When this option is specified, information is written to the report file only for objects that are found to be different. 
- Detailed report. This specifies that a detailed report for the objects is to be written. 
- Show report when finished. When this option is selected, the report file will be displayed when the compare has completed. 
When viewing the report file in Notepad it is recommended that a non-proportional font (such as Courier New or Fixedsys) is used. The information in the report file is aligned in particular columns, so will display better with these fonts.
You can have <schema> or <table> in your file name. When the compare is run, the schema and object-name of the object being compared are substituted for these. When comparing multiple objects, this allows you to have a different report file for each object.
Note that when you are comparing between different schemas, the Compare schema (eg. the first one specified) is the one substituted in <schema>.
Compare button
This runs the Compare, and shows you the results on the Results tab. To cancel the compare, click on the Abort button (you may neeed to go back to the Options tab to do this).
Viewing the Compare results
These are shown on the Results tab.

This window is divided into three parts, a top grid, and a left and right lower grids:
- thoughout the grids - a tick means the object compares successfully 
- a cross indicates that differences were found in the compare 
- a dot indicates that nothing was compared. You will see this for tables that are in one database/schema but not the other. 
- a zero indicates that there were no related objects for that table to compare. 
 
Top grid
This shows you one row per table compared. For each row, there is a column in the grid showing you how each Component of the table compares. These correspond to the components selected in the What to Compare box in the Options tab.
- click on a tick or cross in the top grid to show you details of that compare in the left lower grid. 
- clicking on a particular index in the left lower grids will show you details of the indexes in the right lower grid. 
- click on View > Only Show Differences to only show rows in the top grid when the objects are different. This is handy of you are comparing a lot of objects, and just want to see the ones that are different. 
Left lower grid
Shows details of the item highlighted in the top grid.
In the example of indexes:
- in the the left lower grid you will see the list of the indexes in the two tables. 
- For each of these, the OK column shows you whether the index compares successfully or not. The Differences column gives a brief summary of what is different between the two indexes. 
Right lower grid
- there is one row in the right lower grid per parameter being compared. This correspond to the Parameters for Index selection in the Options tab. 
- the OK column show whether the parameters compare successfully. 
How Compare Objects works
Comparing "related objects" (such as indexes)
When comparing a related object (such as an index), Compare Objects will get the list of all indexes for the two tables. It will then go through these lists of indexes to determine which indexes "match" (eg. are the "same" index in both tables) and which indexes do not "match" (eg. are defined in one table but not the other).
The key to this matching process is the compare parameters. These are the parameters which are used to determine whether two objects are "the same". For instance, when we compare the indexes from two tables, we do not compare on index name, instead we comnpare on the index-columns - if these are the same then the two indexes are "the same".
The following table shows how some common objects are compared:
| Object | Compare Parameters | Parameters Compared | Parameters Not Compared | 
|---|---|---|---|
| Index | index columns | type (unique/non-unique) | table name, index name | 
| Foreign Key | referenced table, fk columns, referenced columns | update rule, delete rule | constraint name | 
| Primary Key | pk columns | 
 | 
 | 
| Check Constraint | constraint text | 
 | constraint name | 
Comparing Foreign Keys
When you are comparing tables in two different schemas, AQT will also look at the schema of the referenced tables.
For instance suppose one table has the following foreign key:
alter table TEST.DEPARTMENT
foreign key (ADMRDEPT)
references TEST.DEPT_INFO (DEPTNO)
This will be considered the same as the foreign key on PROD.DEPARTMENT if it has the following definition:
alter table PROD.DEPARTMENT
foreign key (ADMRDEPT)
references PROD.DEPT_INFO (DEPTNO)
It will not compare successfully if this definition had:
references TEST.DEPT_INFO (DEPTNO)
In other words, if the schema of the Referenced table (DEPT_INFO) is the same as the table schema, AQT will assume that the same applies for the compared-to table.
Comparing Aliases and Synonyms
Similar logic is used for Aliases and Synonyms - if the referenced object has the same name as the table schema, AQT will assume the same applies for the compare-to table.
Comparing Views Triggers and Functions
These objects are difficult objects to compare, as they are generally defined by a block of text, such as a view or procedure definition. A "simple" compare of this text will show a difference when only a single byte is different; this can often happen due to differences in formatting such as extra blanks or linefeeds.
AQT will deal with in two ways
Unformatting the Text
Firstly, AQT will unformat the text before comparing it. Unformatting the text will remove all linefeeds, tabs and extra blanks. By doing this, AQT is more able to deal with simple differences in the formatting of the definitions.
When you view the compare results, you will be shown the unformatted text in the compare results. This may be less readable than the original view / procedure definition, however is useful for seeing the difference between the definitions.
Changing the Schema Name
If you are comparing objects from two different schemas, AQT will do a replace the schema names in the values. This is best demonstrated with an example.
Suppose you are comparing view Prod.Cust_Orders to Dev.Cust_Orders. Prod.Cust_Orders has the definition:
Create View Prod.Cust_Orders As
Select * From Prod.Customer_Details a, Prod.Order_Details a,
Where a.Cust_Code=b.Cust_Code
Whereas Dev.Cust_Orders has the definition:
Create View Dev.Cust_Orders As
Select * From Dev.Customer_Details a, Dev.Order_Details a,
Where a.Cust_Code=b.Cust_Code
To compare these two definitions, AQT will replace "Dev." with "Prod." in the second definition before comparing it with the first. This will provide a more realistic comparison of the definitions as all the view text.
Comparing objects across different database types
AQT can compare objects across different database types (eg. Oracle to SQL Server). In this case:
- only parameters that are in common to both databases are compared. For instance, Oracle tables have parameters of Tablespace and Description; SQL Server tables do not; these parameters will therefore be excluded from the compare. They will not appear in the Parameter For box 
- when comparing columns, AQT will convert column types between databases. For instance, it will deem Oracle NUMERIC and SQL Server DECIMAL to be the same, Oracle LONG and SQL Server TEXT to be the same. 
AQT's Compare between different databases is good but not perfect. There are many small differences between databases that are difficult for the Compare Objects to deal with.
Problem with Collation orders
There is a known problem when comparing databases which have different collation orders. This can apply when comparing (for instance) DB2 z/OS tables to a tables in a non-DB2 z/OS platform.
AQT obtains the list of tables to compare by running a query such as select name from systables order by 1. However if your table names contain numbers, this list of table can be returned in different orders. This will cause the AQT object compare function to think that the some tables exist on one system but not the other (and vica-versa), when in fact they exist on both systems.
At this stage we do not have a resolution to this problem.
Generate Resync script
Compare Objects has the ability to generate a script to resync the two objects / schemas.
Options controlling this are given on the Resync tab, as shown below.

These options are described below:
- Generate Resync Script? This specified whether you are wishing to create a resync script, and if so which schema is to be resynced to the other. 
- File. This gives the name of the resync script file. 
- Create objects if not present. This option is only relevant if you are comparing schemas, rather than a single object. It specifies whether you want the resync script to include Create statements - this will be done if the object is not present in the schema being resynced, but is in the other schema. 
- Drop objects if not present in other schema. This option is only relevant if you are comparing schemas, rather than a single object. It specifies whether you want the resync script to include Drop statements - this will be done if the object is present in the schema being resynced, but is not presnt in the other schema. 
Controlling what objects and attributes are resynced
AQT will attempt to resync all differences found during the compare process.Therefore, you select which objects and attributes you wish to have resynced by the What to Compare box on the Options tab.
For example, to prevent AQT attempting to resync the Null attributes on columns, click on Columns in the What to Compare box, then de-select Nulls on the Attribute for Columns box.
AQT cannot resync all attributes
Not all differences found by the compare can be resynced. There are a number of attributes that are set when the object is created and can't subsequently be changed.
When this happens, you will get messages such as the following in the resync file:
--Note: AQT is unable to generate the SQL for the following change
--Change Table COMP2.DEPARTMENT value of Tablespace from "TESTST2" to "USERSPACE1"
In the case of comparing tables, more complex changes to tables can often only be achieved by dropping and recreating the tables. AQT will not do this, but instead will attempt to modify the table by means of ALTER statements. If this cannot be done the difference will remain as an unsynced difference.
When the compare completes, the result of the compare is given in the status-bar at the bottom of the windows. The number of differences which can't be resynced are given in the Failed count.

Multiple Resync Scipts
You can have <schema> or <table> in your resync file name. When the compare is run, the schema and object-name of the object being compared are substituted for these. When comparing multiple objects, this allows you to have a different resync file for each object.
Note that when you are comparing between different schemas, the schema being resynced (eg. the schema to which changes will be applied) is the one substituted in <schema>. This may be different from the schema that is substituted for <schema> in the report file name.
Drop / Recreating Objects
Some objects (such as indexes) have limited ability to have their definitions altered once they have been created.
The definition of these objects can only be resynced by dropping and recreating the object.
AQT will do this if:
- your database has been configured (within AQT) to use drop / recreate for this object 
- the option Allow drop / redefine of index and other objects has been selected 
You may wish to de-select Allow drop / redefine of index and other objects if your table has a large number of rows so that the recreation of the index would be a time-consuming process.
AQT will not use drop / recreate for tables. Your data is not at risk.
When recreating indexes, retain existing name
When AQT redefines an object (such as an index) it has a choice of which name to use for the object:
- the existing name for the object 
- the name of the object being resynced to 
Example:
suppose you have indexes:
- COMP.INDEX_CUST01 in Database1 
- COMP.INDEX_CUST_UNIQ in Database2 
As these indexes are on the same columns, AQT will deem them to be the "same" index. However some of the other attributes of the indexes (such as Unique flag) may be different.
To resync their definition, AQT may choose to drop and recreate COMP.INDEX_CUST_UNIQ to make it the same as COMP.INDEX_CUST01.
When recreating COMP.INDEX_CUST_UNIQ what name shall AQT use? There are two choices:
- COMP.INDEX_CUST_UNIQ (the same name the index was called previously) 
- COMP.INDEX_CUST01 (the name of the index being resynced to) 
When the When recreating indexes, retain existing name option is selected, AQT will use the first choice.
Limitations of Object Resync
Generating a resync script is a complex process that has a number of limitations. In all cases it is recommended that you view the resync script, to ensure that it is doing something sensible, before you run it.
Some of the limitations are as follows. This relates to case of comparing tables:
- if you have renamed a table, the compare will not detect this. The resync will drop the old table and create another one with the new name. This may result in the loss of data. - To avoid possible problems such as this, you can de-select the option DROP objects if not present in other schema. 
- similarly, AQT cannot tell that you have renamed a column. It will drop the column / add a new one. Again, this can result in the loss of data. 
- there are a number of differences that AQT cannot resync. In these cases AQT will give a warning message to this effect. 
- for DB2 for LUW, when columns are dropped or have their data type changed, the table can be placed into reorg-pending state. You can only do further operations on the table once a reorg has been done. AQT will not do this for you - this is something that will have to be done manually. You may need to do this multiple-times during the course of the resync script. 
- if you have a large resync script that is creating a lot of objects, the creation of foreign keys, views and/or triggers may fail as the dependent objects have not been created yet. The solution is for these objects to be created at the end of the script (after the changes to the tables have been done). - AQT will currently not do this; this is something we will consider as a future enhancement. 
Running Compare Objects in batch mode
Compare Objects can be scripted - this allows it to be run either from the Run SQL window or as an unattended batch process.
How to do this is described in scripting - objcomp.