Package org.eclipse.net4j.db
Class DBUtil
java.lang.Object
org.eclipse.net4j.db.DBUtil
A utility class with various static factory and convenience methods.
- Author:
- Eike Stepper
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic interfaceArow handlerwith amethodthat is called once per row deserialized withinDBUtil.deserializeTable().static interfaceCall-back interface with amethodthat is called after a number of table rows have been handled by one of the subtypes of this interface.static interfacestatic interface
- 
Field SummaryFields
- 
Method SummaryModifier and TypeMethodDescriptionstatic intstatic longstatic BatchedStatementbatched(PreparedStatement delegate, int batchSize) static intclearTable(Connection connection, String tableName) static intclearTable(Connection connection, IDBTable table) static Exceptionclose(Connection connection) static Exceptionstatic Exceptionstatic booleancontainsName(Set<String> names, String name, boolean caseSensitive) static IDBSchemacopySchema(IDBSchema source) static IDBConnectionProvidercreateConnectionProvider(DataSource dataSource) static IDBConnectionProvider2createConnectionProvider(DataSource dataSource, String user) static DataSourcecreateDataSource(Map<Object, Object> properties) static DataSourcecreateDataSource(Map<Object, Object> properties, String namespace) static DataSourcestatic IDBSchemacreateSchema(String name) Creates a case-insensitive schema with the givenname.static IDBSchemacreateSchema(String name, boolean caseSensitive, boolean qualifiedTableNames) static voiddeserializeTable(org.eclipse.net4j.util.io.ExtendedDataInput in, Connection connection, IDBTable table, org.eclipse.net4j.util.om.monitor.OMMonitor monitor) static voiddeserializeTable(org.eclipse.net4j.util.io.ExtendedDataInput in, Connection connection, IDBTable table, org.eclipse.net4j.util.om.monitor.OMMonitor monitor, DBUtil.DeserializeRowHandler handler) dropAllTables(Connection connection, String schemaName) dropAllTables(Connection connection, String schemaName, boolean caseSensitive) static voiddump(IDBNamedElement namedElement) static voiddump(IDBNamedElement namedElement, Writer writer) static StringdumpToString(IDBNamedElement namedElement) static booleanequalNames(String name1, String name2, boolean caseSensitive) static voidexecute(Connection connection, CharSequence sql) static <T> Texecute(IDBConnectionProvider connectionProvider, DBUtil.RunnableWithConnection<T> runnable) static voidexecuteBatch(PreparedStatement stmt, int counter) static voidexecuteBatch(PreparedStatement stmt, int counter, boolean checkExactlyOne) static voidforEachTable(Connection connection, String schemaName, boolean caseSensitive, org.eclipse.net4j.util.ConsumerWithException<String, SQLException> tableNameConsumer) getAllSchemaNames(Connection connection) getAllSchemaNames(DatabaseMetaData metaData) getAllSchemaTableNames(Connection connection) Deprecated.getAllSchemaTableNames(DatabaseMetaData metaData) Deprecated.As of 4.2 usegetAllSchemaNames(DatabaseMetaData).getAllTableNames(Connection connection, String schemaName) getAllTableNames(Connection connection, String schemaName, boolean caseSensitive) static IDBAdaptergetDBAdapter(String adapterName) Retrieves anadapterfrom theadapter registry.static intgetRowCount(Connection connection, String tableName) Returns the number of rows contained in the given table.static intgetRowCount(ResultSet resultSet) Returns the number of rows contained in the given result set.static booleanisOptional(IDBElement element) static booleanstatic Stringstatic Stringstatic Stringstatic IDBDatabaseopenDatabase(IDBAdapter adapter, IDBConnectionProvider connectionProvider, String schemaName) static IDBDatabaseopenDatabase(IDBAdapter adapter, IDBConnectionProvider connectionProvider, String schemaName, boolean fixNullableIndexColumns) static IDBDatabaseopenDatabase(IDBAdapter adapter, IDBConnectionProvider connectionProvider, String schemaName, boolean fixNullableIndexColumns, boolean qualifiedTableNames) static Stringstatic IDBSchemareadSchema(IDBAdapter adapter, Connection connection, String name) static IDBSchemareadSchema(IDBAdapter adapter, Connection connection, String name, boolean fixNullableIndexColumns) static IDBSchemareadSchema(IDBAdapter adapter, Connection connection, String name, boolean fixNullableIndexColumns, boolean qualifiedTableNames) static voidreadSchema(IDBAdapter adapter, Connection connection, IDBSchema schema) static ExceptionrollbackSilently(Connection connection) static Object[]select(Connection connection, String where, IDBField... fields) static intselect(Connection connection, IDBRowHandler rowHandler, String where, IDBField... fields) static intselect(Connection connection, IDBRowHandler rowHandler, IDBField... fields) static intselectMaximumInt(Connection connection, IDBField field, String... where) static longselectMaximumLong(Connection connection, IDBField field, String... where) static intselectMinimumInt(Connection connection, IDBField field, String... where) static longselectMinimumLong(Connection connection, IDBField field, String... where) static voidserializeTable(org.eclipse.net4j.util.io.ExtendedDataOutput out, Connection connection, IDBTable table, String tableAlias, String sqlSuffix) static voidserializeTable(org.eclipse.net4j.util.io.ExtendedDataOutput out, Connection connection, IDBTable table, String tableAlias, String sqlSuffix, DBUtil.SerializeRowHandler handler) static booleansetAutoCommit(Connection connection, boolean autoCommit) static booleansetOptional(IDBElement element, boolean optional) static voidsqlDump(Connection conn, String sql) Deprecated.Should only be used when debugging.static voidsqlDump(IDBConnectionProvider connectionProvider, String sql) Deprecated.Should only be used when debugging.static Stringstatic intupdate(Connection connection, String sql) static intupdate(PreparedStatement stmt, boolean exactlyOne) Execute update on the given prepared statement and handle common cases of return values.
- 
Field Details- 
QUOTE- Since:
- 4.12
- See Also:
 
- 
MAX_BATCH_SIZEpublic static final int MAX_BATCH_SIZE- Since:
- 4.2
 
- 
DISABLE_QUOTED_NAMESpublic static final boolean DISABLE_QUOTED_NAMES- Since:
- 4.12
 
- 
PROP_ENABLE_NOISY_CLOSEA system property to enable noisy close, i.e. exception catch in close methods are thrown asDBExceptionexception.- Since:
- 4.4
- See Also:
 
- 
ALL_TABLE_NAME_TYPES- Since:
- 4.12
 
 
- 
- 
Method Details- 
dumpToString- Since:
- 4.2
 
- 
dump- Since:
- 4.2
 
- 
dump- Throws:
- IOException
- Since:
- 4.2
 
- 
openDatabasepublic static IDBDatabase openDatabase(IDBAdapter adapter, IDBConnectionProvider connectionProvider, String schemaName) - Since:
- 4.2
 
- 
openDatabasepublic static IDBDatabase openDatabase(IDBAdapter adapter, IDBConnectionProvider connectionProvider, String schemaName, boolean fixNullableIndexColumns) - Since:
- 4.2
 
- 
openDatabasepublic static IDBDatabase openDatabase(IDBAdapter adapter, IDBConnectionProvider connectionProvider, String schemaName, boolean fixNullableIndexColumns, boolean qualifiedTableNames) - Since:
- 4.12
 
- 
createSchemaCreates a case-insensitive schema with the givenname.
- 
createSchemapublic static IDBSchema createSchema(String name, boolean caseSensitive, boolean qualifiedTableNames) - Since:
- 4.12
 
- 
readSchema- Since:
- 4.2
 
- 
readSchema- Since:
- 4.2
 
- 
readSchemapublic static IDBSchema readSchema(IDBAdapter adapter, Connection connection, String name, boolean fixNullableIndexColumns) - Since:
- 4.2
 
- 
readSchemapublic static IDBSchema readSchema(IDBAdapter adapter, Connection connection, String name, boolean fixNullableIndexColumns, boolean qualifiedTableNames) - Since:
- 4.12
 
- 
copySchema- Since:
- 4.2
 
- 
createDataSource
- 
createDataSource
- 
createDataSource
- 
createConnectionProvider
- 
createConnectionProvider- Since:
- 4.3
 
- 
getDBAdapterRetrieves anadapterfrom theadapter registry.If Eclipse is running adapters are automatically created from descriptors that are contributed to the extension point org.eclipse.net4j.db.dbAdapters.In standalone scenarios the needed adapter instances must be registered with the adapter registrymanually.
- 
batchedpublic static BatchedStatement batched(PreparedStatement delegate, int batchSize) throws DBException - Throws:
- DBException
- Since:
- 4.5
 
- 
close
- 
close
- 
close
- 
isOptional- Since:
- 4.6
 
- 
setOptional- Since:
- 4.6
 
- 
setAutoCommit- Since:
- 4.2
 
- 
rollbackSilently- Since:
- 4.2
 
- 
quoted- Since:
- 4.12
 
- 
name- Since:
- 4.12
 
- 
name- Since:
- 4.12
 
- 
name- Since:
- 4.12
 
- 
equalNames- Since:
- 4.12
 
- 
containsName- Since:
- 4.12
 
- 
getAllSchemaNames- Since:
- 4.2
 
- 
getAllSchemaNames- Since:
- 4.2
 
- 
getAllTableNames
- 
getAllTableNamespublic static List<String> getAllTableNames(Connection connection, String schemaName, boolean caseSensitive) - Since:
- 4.12
 
- 
forEachTablepublic static void forEachTable(Connection connection, String schemaName, boolean caseSensitive, org.eclipse.net4j.util.ConsumerWithException<String, SQLException> tableNameConsumer) - Since:
- 4.12
 
- 
dropAllTables- Since:
- 4.0
 
- 
dropAllTablespublic static List<Exception> dropAllTables(Connection connection, String schemaName, boolean caseSensitive) - Since:
- 4.12
 
- 
asInt- Since:
- 4.2
 
- 
asLong- Since:
- 4.2
 
- 
selectMinimumIntpublic static int selectMinimumInt(Connection connection, IDBField field, String... where) throws DBException - Throws:
- DBException
- Since:
- 3.0
 
- 
selectMinimumLongpublic static long selectMinimumLong(Connection connection, IDBField field, String... where) throws DBException - Throws:
- DBException
- Since:
- 3.0
 
- 
selectMaximumIntpublic static int selectMaximumInt(Connection connection, IDBField field, String... where) throws DBException - Throws:
- DBException
- Since:
- 3.0
 
- 
selectMaximumLongpublic static long selectMaximumLong(Connection connection, IDBField field, String... where) throws DBException - Throws:
- DBException
- Since:
- 3.0
 
- 
executepublic static <T> T execute(IDBConnectionProvider connectionProvider, DBUtil.RunnableWithConnection<T> runnable) - Since:
- 4.2
 
- 
execute- Since:
- 4.2
 
- 
executeBatch- Since:
- 4.1
 
- 
executeBatch- Since:
- 4.1
 
- 
update
- 
updateExecute update on the given prepared statement and handle common cases of return values.- Parameters:
- stmt- the prepared statement
- exactlyOne- if- true, the update count is checked to be- 1. Else the update result is only checked so that the update was successful (i.e. result code != Statement.EXECUTE_FAILED).
- Returns:
- the update count / execution result as returned by PreparedStatement.executeUpdate(). Can be used by the caller to perform more advanced checks.
- Throws:
- SQLException- if- PreparedStatement.executeUpdate()throws it.
- IllegalStateException- if the check indicated by- excatlyOneindicates an error.
- Since:
- 4.0
 
- 
clearTable- Since:
- 4.1
 
- 
clearTable- Since:
- 4.1
 
- 
selectpublic static int select(Connection connection, IDBRowHandler rowHandler, String where, IDBField... fields) throws DBException - Throws:
- DBException
 
- 
selectpublic static int select(Connection connection, IDBRowHandler rowHandler, IDBField... fields) throws DBException - Throws:
- DBException
 
- 
selectpublic static Object[] select(Connection connection, String where, IDBField... fields) throws DBException - Throws:
- DBException
 
- 
getRowCountReturns the number of rows contained in the given result set.The statementof the result set must have been created withTYPE_SCROLL_INSENSITIVE.- Throws:
- DBException
- Since:
- 4.0
 
- 
getRowCountReturns the number of rows contained in the given table.- Throws:
- DBException
- Since:
- 4.5
 
- 
serializeTablepublic static void serializeTable(org.eclipse.net4j.util.io.ExtendedDataOutput out, Connection connection, IDBTable table, String tableAlias, String sqlSuffix) throws DBException, IOException - Throws:
- DBException
- IOException
- Since:
- 3.0
 
- 
serializeTablepublic static void serializeTable(org.eclipse.net4j.util.io.ExtendedDataOutput out, Connection connection, IDBTable table, String tableAlias, String sqlSuffix, DBUtil.SerializeRowHandler handler) throws DBException, IOException - Throws:
- DBException
- IOException
- Since:
- 4.1
 
- 
deserializeTablepublic static void deserializeTable(org.eclipse.net4j.util.io.ExtendedDataInput in, Connection connection, IDBTable table, org.eclipse.net4j.util.om.monitor.OMMonitor monitor) throws IOException - Throws:
- IOException
- Since:
- 4.0
 
- 
deserializeTablepublic static void deserializeTable(org.eclipse.net4j.util.io.ExtendedDataInput in, Connection connection, IDBTable table, org.eclipse.net4j.util.om.monitor.OMMonitor monitor, DBUtil.DeserializeRowHandler handler) throws IOException - Throws:
- IOException
- Since:
- 4.1
 
- 
trace- Since:
- 3.0
 
- 
isTracerEnabledpublic static boolean isTracerEnabled()- Since:
- 4.2
 
- 
sqlDumpDeprecated.Should only be used when debugging.For debugging purposes ONLY!- Since:
- 3.0
 
- 
sqlDumpDeprecated.Should only be used when debugging.For debugging purposes ONLY!- Since:
- 3.0
 
- 
getAllSchemaTableNamesDeprecated.As of 4.2 usegetAllSchemaNames(Connection).- Since:
- 3.0
 
- 
getAllSchemaTableNamesDeprecated.As of 4.2 usegetAllSchemaNames(DatabaseMetaData).- Since:
- 3.0
 
 
- 
getAllSchemaNames(Connection).