DbUnit does not use System properties anymore since version 2.0. DbUnit use a configuration object, DatabaseConfig, to query and set feature flags and property values for a IDatabaseConnection. It is possible to change DbUnit behaviors, such as using batched statements or not, using the getFeature, setFeature, getProperty, and setProperty methods of DatabaseConfig.
While feature flags are always boolean, property values are arbitrary objects. Note that starting with dbunit 2.4.6 features can also be set using the setProperty method.
The following sample displays the batched statement feature status:
String id = "/features/batchedStatements"; DatabaseConfig config = connection.getConfig(); if (config.getFeature(id)) { System.out.println("Batched statements is enabled."); } else { System.out.println("Batched statements is disabled."); }
Feature ID | /features/batchedStatements |
Default | false |
Description | Enable or disable usage of JDBC batched statement by DbUnit. |
Feature ID | /features/caseSensitiveTableNames |
Default | false |
Description | Enable or disable case sensitive table names. If enabled, Dbunit handles all table names in a case sensitive way. |
Feature ID | /features/qualifiedTableNames |
Default | false |
Description | Enable or disable multiple schemas support. If enabled, Dbunit access tables with names fully qualified by schema using this format: SCHEMA.TABLE. |
Note | This feature was not compatible with the escape pattern property until the 2.2.1 release. Since then the two properties can be mixed without problem: each element will be properly escaped. |
Feature ID | /features/datatypeWarning |
Default | true |
Description | Enable or disable the warning message displayed when DbUnit encounter an unsupported data type. |
Feature ID | /features/skipOracleRecycleBinTables |
Default | false |
Description | Enable or disable the processing of oracle recycle bin tables (tables starting with BIN$). Oracle 10g recyle bin tables may break DbUnit's assumption of tables name uniqueness within a schema since these table are case sensitive. Enable this feature for Oracle 10g databases until the bug in the oracle driver is fixed, which incorrectly reports this system tables to DbUnit. |
Property ID | /properties/escapePattern |
Default | none |
Description | Allows schema, table and column names escaping. The property value
is an escape pattern where the ? is replaced by the name. For example,
the pattern "[?]" is expanded as "[MY_TABLE]" for a table named "MY_TABLE".
The most common escape pattern is "\"?\"" which surrounds the table name
with quotes (for the above example it would result in "\"MY_TABLE\"").
As a fallback if no questionmark is in the given String and its length is one it is used to surround the table name on the left and right side. For example the escape pattern "\"" will have the same effect as the escape pattern "\"?\"". |
Note | This property was not compatible with the qualified table names feature until 2.2.1. Since then the two properties can be mixed resulting in each element properly escaped. |
Property ID | /properties/tableType |
Type | String[] |
Description | Used to configure the list of table types recognized by DbUnit. See java.sql.DatabaseMetaData.getTables for possible values. |
Default | String[]{"TABLE"} |
Property ID | /properties/datatypeFactory |
Default | org.dbunit.dataset.datatype.DefaultDataTypeFactory |
Description | Used to configure the DataType factory. You can replace the default factory to add support for non-standard database vendor data types. The Object must implement org.dbunit.dataset.datatype.IDataTypeFactory. |
Note | The following factories are currently available:
|
Property ID | /properties/statementFactory |
Default | org.dbunit.database.statement.PreparedStatementFactory |
Description | Used to configure the statement factory. The Object must implement org.dbunit.database.statement.IStatementFactory. |
Property ID | /properties/resultSetTableFactory |
Default | org.dbunit.database.CachedResultSetTableFactory |
Description | Used to configure the ResultSet table factory. The Object must implement org.dbunit.database.IResultSetTableFactory. |
Property ID | /properties/primaryKeyFilter |
Default | none |
Description | Use to override primary keys detection. The Object must implement org.dbunit.dataset.filter.IColumnFilter. |
Property ID | /properties/mssql/identityColumnFilter |
Default | none |
Description | Use to override IDENTITY column detection. The Object must implement org.dbunit.dataset.filter.IColumnFilter. |
Property ID | /properties/batchSize |
Default | 100 |
Description | Integer object giving the size of batch updates. |
Property ID | /properties/fetchSize |
Default | 100 |
Description | Integer object giving the statement fetch size for loading data into a result set table. |
Property ID | /properties/metadataHandler |
Default | org.dbunit.database.DefaultMetadataHandler |
Description | Used to configure the handler used to control database metadata related methods. The Object must implement org.dbunit.database.IMetadataHandler. |
Note | The following RDBMS specific handlers are currently available:
|