sf.util.DatabaseUtility Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of schemacrawler Show documentation
Show all versions of schemacrawler Show documentation
SchemaCrawler is an open-source Java API that makes working with database metadata as easy as working with plain old Java objects. SchemaCrawler is also a database schema discovery and comprehension, and schema documentation tool. You can search for database schema objects using regular expressions, and output the schema and data in a readable text format. The output is designed to be diff-ed against other database schemas.
/*
*
* SchemaCrawler
* http://www.schemacrawler.com
* Copyright (c) 2000-2016, Sualeh Fatehi.
*
* This library is free software; you can redistribute it and/or modify it under the terms
* of the GNU Lesser General Public License as published by the Free Software Foundation;
* either version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License along with this
* library; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
* Boston, MA 02111-1307, USA.
*
*/
package sf.util;
import static java.util.Objects.requireNonNull;
import static sf.util.Utility.isBlank;
import static sf.util.Utility.readResourceFully;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.SQLWarning;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;
import java.util.logging.Level;
import java.util.logging.Logger;
import schemacrawler.schemacrawler.SchemaCrawlerException;
/**
* Utility methods.
*
* @author Sualeh Fatehi
*/
public final class DatabaseUtility
{
private static final Logger LOGGER = Logger
.getLogger(DatabaseUtility.class.getName());
public static void checkConnection(final Connection connection)
throws SchemaCrawlerException
{
try
{
requireNonNull(connection, "No connection provided");
if (connection.isClosed())
{
throw new SQLException("Connection is closed");
}
}
catch (final NullPointerException | SQLException e)
{
throw new SchemaCrawlerException("Bad database connection", e);
}
}
public static Statement createStatement(final Connection connection)
throws SchemaCrawlerException, SQLException
{
checkConnection(connection);
return connection.createStatement();
}
public static void executeScriptFromResource(final Connection connection,
final String scriptResource)
throws SchemaCrawlerException
{
try (final Statement statement = createStatement(connection);)
{
final String sqlScript = readResourceFully(scriptResource);
if (!isBlank(sqlScript))
{
for (final String sql: sqlScript.split(";"))
{
if (isBlank(sql))
{
continue;
}
final ResultSet resultSet = executeSql(statement, sql);
if (resultSet != null)
{
LOGGER
.log(Level.WARNING,
new StringFormat("Ignoring results from query, %s", sql));
resultSet.close();
}
}
}
}
catch (final SQLException e)
{
System.err.println(e.getMessage());
LOGGER.log(Level.WARNING, e.getMessage(), e);
}
}
public static ResultSet executeSql(final Statement statement,
final String sql)
{
ResultSet results = null;
if (statement == null)
{
return results;
}
if (isBlank(sql))
{
LOGGER.log(Level.FINE,
"No SQL provided",
new RuntimeException("No SQL provided"));
return results;
}
try
{
statement.clearWarnings();
final boolean hasResults = statement.execute(sql);
if (hasResults)
{
results = statement.getResultSet();
}
else
{
final int updateCount = statement.getUpdateCount();
LOGGER.log(Level.FINE,
new StringFormat("No results. Update count of %d for query: %s",
updateCount,
sql));
}
SQLWarning sqlWarning = statement.getWarnings();
while (sqlWarning != null)
{
LOGGER.log(Level.INFO, sqlWarning.getMessage(), sqlWarning);
sqlWarning = sqlWarning.getNextWarning();
}
return results;
}
catch (final SQLException e)
{
LOGGER.log(Level.WARNING,
e,
new StringFormat("Error executing SQL, %s", sql));
return null;
}
}
public static long executeSqlForLong(final Connection connection,
final String sql)
throws SchemaCrawlerException
{
final Object longValue = executeSqlForScalar(connection, sql);
// Error checking
if (longValue == null || !(longValue instanceof Number))
{
throw new SchemaCrawlerException("Cannot get an integer value result from SQL");
}
return ((Number) longValue).longValue();
}
public static Object executeSqlForScalar(final Connection connection,
final String sql)
throws SchemaCrawlerException
{
try (final Statement statement = createStatement(connection);
final ResultSet resultSet = executeSql(statement, sql);)
{
if (resultSet == null)
{
return null;
}
// Error checking
if (resultSet.getMetaData().getColumnCount() != 1)
{
throw new SchemaCrawlerException("Too many columns of data returned");
}
final Object scalar;
if (resultSet.next())
{
scalar = resultSet.getObject(1);
}
else
{
LOGGER
.log(Level.WARNING,
new StringFormat("No rows of data returned for query, %s", sql));
scalar = null;
}
// Error checking
if (resultSet.next())
{
throw new SchemaCrawlerException("Too many rows of data returned");
}
return scalar;
}
catch (final SQLException e)
{
throw new SchemaCrawlerException(sql, e);
}
}
/**
* Reads a single column result set as a list.
*
* @param results
* Result set
* @return List
* @throws SQLException
* On an exception
*/
public static List readResultsVector(final ResultSet results)
throws SQLException
{
final List values = new ArrayList<>();
if (results == null)
{
return values;
}
try
{
while (results.next())
{
final String value = results.getString(1);
if (!results.wasNull() && !isBlank(value))
{
values.add(value.trim());
}
}
}
finally
{
results.close();
}
return values;
}
private DatabaseUtility()
{ // Prevent instantiation
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy