Skip to content

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

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 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 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 for Entity Relationship Diagram 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

CreateDataStoreDataDictionary Command Editor for Entity Relationship Layout Parameters (see full-size image)

Troubleshooting

See the main TSTool Troubleshooting documentation.

See Also