TSTool / Command / CreateDataStoreDataDictionary
Overview
The CreateDataStoreDataDictionary
command creates an HTML data dictionary and
Entity Relationship (ER) Diagram for a database datastore.
The data dictionary output from the command is an HTML file that provides:
- General database information.
- A list of tables and views, which link to table details.
- For each table, the details for the columns in the table, including name, data type, remarks (description), whether null is allowed, and indication of whether the columns are primary or foreign keys.
- Reference tables have all of their data listed to help understand relationships.
The Java DatabaseMetaData
class is used to access database metadata.
Current limitations are as follows:
- The command has been tested with SQL Server, Microsoft Access, MySQL, Oracle, and PostgreSQL databases. The command may or may not work with other databases.
- SQL Server is supported to a limited degree. Table and column descriptions currently cannot be retrieved due to limitations in SQL Server database drivers.
- Data dictionary output is only as complete as the metadata defined by the database administrator – there currently is no way to provide additional information via the command, although in the future an ability to provide table and column descriptions using an input table may be implemented.
- The ER Diagram capability is under development.
- Information for procedures, functions, and triggers is not implemented.
Command Editor
The command is available in the following TSTool menu:
- Commands / Datastore Processing
The following dialog is used to edit the command and illustrates the syntax of the command for table parameters.
CreateDataStoreDataDictionary
Command Editor for Table Parameters (see full-size image)
The following dialog is used to edit the command and illustrates the syntax of the command for metadata parameters.
CreateDataStoreDataDictionary
Command Editor for Metadata Parameters (see full-size image)
The following dialog is used to edit the command and illustrates the syntax of the command for data dictionary parameters.
CreateDataStoreDataDictionary
Command Editor for Data Dictionary Parameters (see full-size image)
The following dialog is used to edit the command and illustrates the syntax of the command for entity relationship parameters.
CreateDataStoreDataDictionary
Command Editor for Entity Relationship Diagram Parameters (see full-size image)
Command Syntax
The command syntax is as follows:
CreateDataStoreDataDictionary(Parameter="Value",...)
Command Parameters
Tab | Parameter | Description | Default |
---|---|---|---|
DataStore required |
The name of a database datastore. Can be specified using ${Property} . |
None – must be specified. | |
Tables | ReferenceTables |
A comma-separated list of database reference tables. The content of these tables will be output in their entirety. Can be specified using ${Property} . |
No reference tables |
ExcludeTables |
A comma-separated list of tables to exclude from output, for example to exclude database system tables. Use * as a wildcard. |
Include all tables. | |
Metadata | DataStoreMetaTableForTables |
Name of datastore table containing metadata for tables (see below), used for databases such as SQLite that don't store metadata in the database. | From database schema. |
DataStoreMetaTableForColumns |
Name of datastore table containing metadata for columns (see below), used for databases such as SQLite that don't store metadata in the database. | From database schema. | |
MetaTableForTables |
Name of table containing metadata for tables (see below), used for databases such as SQLite that don't store metadata in the database. Use this approach if the datastore contains a metadata table that must be queried into a table to adjust column names to match the required names. | From database schema. | |
MetaTableForColumns |
Name of table containing metadata for columns (see below), used for databases such as SQLite that don't store metadata in the database. Use this approach if the datastore contains a metadata table that must be queried into a table to adjust column names to match the required names. | From database schema. | |
Data Dictionary | OutputFile |
The name of the file for the HTML data dictionary. Can be specified using ${Property}. | None. |
SurroundWithPre |
Specify as True if comments for table columns should be surrounded with <pre></pre> in output, useful if comments included newlines for formatting. In this case Newline and EncodeHtmlChars are ignored. |
False |
|
Newline |
String to replace newline in table column comments. For example use <br> to preserve newlines in HTML output. Specifying True will cause EncodeHtmlChars to be ignored. |
Space | |
EncodeHtmlChars |
Specify as True if characters such as < should be encoded to display in HTML, False to pass through comment content as is with no encoding. |
True |
|
Entity Relationship Diagram | ERDiagramLayoutTableID |
The table identifier for the table supplying ER Diagram coordinate information. Can be specified using ${Property} . |
None – must be specified if ER Diagram is created. |
ERDiagramLayoutTableXColumn |
The name of the column in the layout table containing the X coordinates for the ER Diagram. Coordinates should be specified in points (1/72 of inch) as position on page size. Can be specified using ${Property} . |
None – must be specified. | |
ERDiagramLayoutTableYColumn |
The name of the column in the layout table containing the Y coordinates for the ER Diagram. Can be specified using ${Property} . |
None – must be specified. | |
ERDiagramPageSize |
The page size for the ER Diagram layout. Currently this defaults to 11x17 (B). | B |
|
ERDiagramOrientation |
The orientation of the ER Diagram. | Landscape |
|
ViewERDiagram |
Indicate whether the ER Diagram should be shown in a window when the commands are run. | False |
The following column names are required for the table or view specified with the
DataStoreMetaTableForTables
command parameter.
Metadata are only required when the database does not store metadata in database schema,
such as for SQLite.
Metatable Columns for Table Metadata
Column Name | Description |
---|---|
id |
Primary identifier that is used to link column metadata (see below). |
name |
Table name. |
description |
Table description. |
The following column names are required for the table or view specified with the
DataStoreMetaTableForColumns
command parameter.
Metadata are only required when the database does not store metadata in database schema,
such as for SQLite.
Metatable Columns for Column Metadata
Column Name | Description |
---|---|
table_id |
Foreign key value matching the id column value in the table metadata table (see above). |
name |
Column name. |
description |
Column description. |
Examples
See the automated tests.
The following is an example of an Excel workbook with ER Diagram layout data, which can be read with the
ReadTableFromExcel
command.
CreateDataStoreDataDictionary
Command Editor for Entity Relationship Layout Parameters (see full-size image)
Troubleshooting
See the main TSTool Troubleshooting documentation.
See Also
ReadTableFromExcel
command