Setting up the correct configurations is essential for smooth and secure data integration. Understanding the right properties and parameters can significantly optimize data handling, streamline querying, and ensure secure connections.
This article explores the model and translator properties available for JDBC data sources and provides an overview of the translator properties.
Following is information about Model and Translator properties and the associated parameters for:
- Available Data Model Properties for JDBC
- Available Translator Properties for JDBC
- Available Translator Properties for Microsoft Active Directory (LDAP)
- Available Translator Properties for the REST Data Source
- Available Translator Properties for Microsoft Entra ID
Available Data Model Properties for JDBC
| Parameter | Description | Default | 
|---|---|---|
| catalog | See DatabaseMetaData.getTables [1] | null | 
| schemaPattern | See DatabaseMetaData.getTables [1] | null | 
| tableNamePattern | See DatabaseMetaData.getTables [1] | null | 
| procedureNamePattern | See DatabaseMetaData.getProcedures [1] | null | 
| tableTypes | Comma separated list - without spaces - of imported table types. See DatabaseMetaData.getTables [1] | null | 
| excludeTables | A case-insensitive regular expression that when matched against a fully qualified table name [2] will exclude it from import. Applied after table names are retrieved. Use a negative look-ahead (?!<inclusion pattern>).*to act as an inclusion filter. | Null | 
| excludeProcedures | A case-insensitive regular expression that when matched against a fully qualified procedure name [2] will exclude it from import. Applied after procedure names are retrieved. Use a negative look-ahead (?!<inclusion pattern>).*to act as an inclusion filter. | null | 
| useFullSchemaName | When false, directs the importer to drop the source catalog/schema from the object name, so that the fully qualified name will be in the form of <model name>.<table name>.Note: When false this may lead to objects with duplicate names when importing from multiple schemas. | true | 
| importKeys | true to import primary and foreign keys. Note: Foreign keys to tables that are not imported will be ignored. | true | 
| autoCreateUniqueConstraints | true to create a unique constraint if one is not found for a foreign key. | true | 
| importIndexes | true to import index/unique key/cardinality information | false | 
| importApproximateIndexes | true to import approximate index information. See DatabaseMetaData.getIndexInfo [1] | true | 
| importProcedures | true to import procedures and procedure columns. Note: It is not always possible to import procedure result set columns due to database limitations. It is also not currently possible to import overloaded procedures. | false | 
| widenUnsignedTypes | true to convert unsigned types to the next widest type. For example, SQL Server reports tinyint as an unsigned type. With this option enabled, tinyint would be imported as a short instead of a byte. | true | 
| quoteNameInSource | false will override the default and direct the service to create source queries using unquoted identifiers. | true | 
| useProcedureSpecificName | true will allow the import of overloaded procedures (which will normally result in a duplicate procedure error) by using the unique procedure-specific name as the service name. This option will only work with JDBC 4.0 compatible drivers that report specific names. | false | 
| useCatalogName | true will use any non-null/non-empty catalog name as part of the name in source, e.g., "catalog"."schema"."table"."column", and in the service runtime name if useFullSchemaName is also true.false will not use the catalog name in either the name in source or the service runtime name. Should be set to false for sources that do not fully support a catalog concept, but return a non-null catalog name in their metadata, such as HSQL. | true | 
| useQualifiedName | true will use name qualification for both the service name and name in source as dictated by the useCatalogName and useFullSchemaName properties. Set to false to disable all qualification for both the service name and the name in source, which effectively ignores the useCatalogName and useFullSchemaName properties. Note: When false this may lead to objects with duplicate names when importing from multiple schemas, which results in an exception. | true | 
| useAnyIndexCardinality | true will use the maximum cardinality returned from DatabaseMetaData.getIndexInfo. importKeys or importIndexes needs to be enabled for this setting to have an effect. This allows for better stats gathering from sources that don’t support returning a statistical index. | false | 
| useQualifiedName | true will use name qualification for both the service name and name in source as dictated by the useCatalogName and useFullSchemaName properties. Set to false to disable all qualification for both the service name and the name in source, which effectively ignores the useCatalogName and useFullSchemaName properties. Note: When false this may lead to objects with duplicate names when importing from multiple schemas, which results in an exception. | true | 
| useAnyIndexCardinality | true will use the maximum cardinality returned from DatabaseMetaData.getIndexInfo. importKeys or importIndexes needs to be enabled for this setting to have an effect. This allows for better stats gathering from sources that don’t support returning a statistical index. | false | 
| importStatistics | true will use database dependent logic to determine the cardinality if none is determined. This is not yet supported by all database types – currently only supported by Oracle and MySQL. | false | 
| importRowIdAsBinary | true will import RowId columns as varbinary values. | false | 
[1] JavaDoc for DatabaseMetaData
[2] The fully qualified name for exclusion is based on the settings of the translator and the specifics of the database. All applicable name parts used by the translator settings (e.g., useQualifiedName and useCatalogName) — including catalog, schema, and table — will be combined as catalogName.schemaName.tableName without quoting. For example, Oracle does not report a catalog, so with default settings, the name used for comparison would be schemaName.tableName.
Available Translator Properties for JDBC
| Parameter | Description | Default | 
|---|---|---|
| DatabaseTimeZone | The time zone of the database. Used when fetching date, time, or timestamp values. | The system default time zone | 
| DatabaseVersion | The specific database version. Used to further tune pushdown support. The base supported version or the version derived from the DatabaseMetadata.getDatabaseProductVersionstring. Automatic detection requires a Connection.If there are circumstances where you are getting an exception from capabilities being unavailable (most likely due to an issue obtaining a Connection), then set DatabaseVersionproperty.Use the JDBCExecutionFactory.usesDatabaseVersion()method to control whether your translator requires a connection to determine capabilities. | |
| TrimStrings | True to trim trailing whitespace from fixed length character strings. Note that the service only has a string, or varchar, type that treats trailing whitespace as meaningful. | false | 
| UseBindVariables | True indicates that PreparedStatementsshould be used and that literal values in the source query should be replaced with bind variables. If false, only LOB values will trigger the use ofPreparedStatements. | true | 
| UseCommentsInSourceQuery | This will embed a leading comment with session/request ID in the source SQL for informational purposes. Can be customized with the CommentFormatproperty. | false | 
| CommentFormat | MessageFormatstring to be used ifUseCommentsInSourceQueryis enabled.Available properties: - 0 - session ID string - 1 - parent request ID string - 2 - request part ID string - 3 - execution count ID string - 4 - user name string - 5 - VDB name string - 6 - VDB version integer - 7 - is transactional Boolean | |
| MaxPreparedInsertBatchSize | The max size of a prepared insert batch. | 2048 | 
| StructRetrieval | Struct retrieval mode can be one of: - OBJECT - getObjectvalue returned- COPY - returned as a SerialStruct- ARRAY - returned as an Array | OBJECT | 
| EnableDependentJoins | For sources that support temporary tables (DB2, Derby, H2, HSQL 2.0+, MySQL 5.0+, Oracle, PostgreSQL, SQLServer, Sybase), allow dependent join pushdown | false | 
Available Translator Properties for Microsoft Active Directory (LDAP)
| Parameter | Description | Default | 
|---|---|---|
| SearchDefaultBaseDN | Default Base DN for LDAP Searches | Null | 
| SearchDefaultScope | Default Scope for LDAP Searches. Can be one of SUBTREE_SCOPE, OBJECT_SCOPE, ONELEVEL_SCOPE. | ONELEVEL_SCOPE | 
| RestrictToObjectClass | Restrict Searches to objectClass named in the Name field for a table | False | 
| UsePagination | Use a PagedResultsControl to page through large results. This is not supported by all directory servers. | False | 
| ExceptionOnSizeLimitExceeded | Set to true to throw an exception when a SizeLimitExceededException is received and a LIMIT is not properly enforced. | False |