📄 dbutils.java
字号:
/*
* $Header: /cvsroot/mvnforum/myvietnam/src/net/myvietnam/mvncore/db/DBUtils.java,v 1.15 2004/01/18 19:06:43 minhnn Exp $
* $Author: minhnn $
* $Revision: 1.15 $
* $Date: 2004/01/18 19:06:43 $
*
* ====================================================================
*
* Copyright (C) 2002-2004 by MyVietnam.net
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or any later version.
*
* All copyright notices regarding MyVietnam and MyVietnam CoreLib
* MUST remain intact in the scripts and source code.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*
* Correspondence and Marketing Questions can be sent to:
* info@MyVietnam.net
*
* @author: Minh Nguyen minhnn@MyVietnam.net
* @author: Mai Nguyen mai.nh@MyVietnam.net
*/
package net.myvietnam.mvncore.db;
import java.sql.*;
import javax.sql.DataSource;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import net.myvietnam.mvncore.util.DateUtil;
import net.myvietnam.mvncore.MVNCoreInfo;
/**
*
* <p>Title: </p>
* <p>Description: A database utility class to handle all the database stuffs
* </p>
* <p>Copyright: Copyright (c) 2003</p>
* <p>Company: MyVietnam.net</p>
* @author: Minh Nguyen minhnn@MyVietnam.net
* @author: Mai Nguyen mai.nh@MyVietnam.net
*/
public final class DBUtils {
private static Log log = LogFactory.getLog(DBUtils.class);
public static final int DATABASE_UNKNOWN = 0;
public static final int DATABASE_GENERAL = 1;
public static final int DATABASE_NOSCROLL = 2;
public static final int DATABASE_ORACLE = 10;
public static final int DATABASE_SQLSERVER = 11;
public static final int DATABASE_DB2 = 12;
public static final int DATABASE_SYBASE = 13;
public static final int DATABASE_IMFORMIX = 14;
public static final int DATABASE_MYSQL = 15;
public static final int DATABASE_POSTGRESQL = 16;
public static final int DATABASE_HSQLDB = 17;
public static final int DATABASE_ACCESS = 18;
private static int databaseType = DATABASE_UNKNOWN;
private static boolean useDatasource = false;
private static int maxTimeToWait = 2000;// 2 seconds
private static int minutesBetweenRefresh = 30;// 30 minutes
private static DBConnectionManager connectionManager = null;
private static DataSource dataSource = null;
private static long lastGetConnectionTime = 0;
private static long lastCloseAllConnectionsTime = 0;
// static init of the class
static {
DBOptions option = new DBOptions();
databaseType = option.databaseType;
if (databaseType != DATABASE_UNKNOWN) {
log.info("Set DATABASE_TYPE = " + databaseType);
}
if (option.useDatasource) {
useDatasource = true;
try {
javax.naming.Context context = new javax.naming.InitialContext();
// sample data source = java:comp/env/jdbc/MysqlDataSource
dataSource = (DataSource) context.lookup(option.datasourceName);
log.info("DBUtils : use datasource = " + option.datasourceName);
} catch (javax.naming.NamingException e) {
log.error("Cannot get DataSource: datasource name = " + option.datasourceName, e);
}
} else {
useDatasource = false;
maxTimeToWait = option.maxTimeToWait;
minutesBetweenRefresh = option.minutesBetweenRefresh;
connectionManager = DBConnectionManager.getInstance(option);
log.info("DBUtils : use built-in DBConnectionManager (MAX_TIME_TO_WAIT = " + maxTimeToWait + ", MINUTES_BETWEEN_REFRESH = " + minutesBetweenRefresh + ")");
}
log.info("DBUtils inited. Detailed info: " + MVNCoreInfo.getProductVersion() + " (Build: " + MVNCoreInfo.getProductReleaseDate() + ")");
}
private DBUtils() {// so cannot new an instance
}
/**
* Use this method to get the database type. This method will automatically
* detect the database type. You could override this value by modifying
* the value in mvncore_db_DBOptions.properties
* @return : the database type
*/
public static int getDatabaseType() {
if (databaseType == DATABASE_UNKNOWN) {
Connection connection = null;
try {
connection = DBUtils.getConnection();
DatabaseMetaData dbmd = connection.getMetaData();
String databaseName = dbmd.getDatabaseProductName().toLowerCase();
if (databaseName.indexOf("oracle") != -1) {
databaseType = DATABASE_ORACLE;
} else if (databaseName.indexOf("sql server") != -1) {
databaseType = DATABASE_SQLSERVER;
} else if (databaseName.indexOf("mysql") != -1) {
databaseType = DATABASE_MYSQL;
} else if (databaseName.indexOf("postgresql") != -1) {
databaseType = DATABASE_POSTGRESQL;
} else if (databaseName.indexOf("hsql") != -1) {
databaseType = DATABASE_HSQLDB;
} else {
databaseType = DATABASE_GENERAL;
}
log.info("Auto detect DATABASE_TYPE = " + databaseType);
} catch (Exception ex) {
log.error("Error when running getDatabaseType", ex);
} finally {
DBUtils.closeConnection(connection);
}
}
return databaseType;
}
/**
* Get a connection from the connection pool. The returned connection
* must be closed by calling DBUtils.closeConnection()
* @return : a new connection from the pool if succeed
* @throws SQLException : if cannot get a connection from the pool
*/
public static Connection getConnection() throws SQLException {
long now = System.currentTimeMillis();
lastGetConnectionTime = now;
// now check if we have not close all connections to refresh
// after MINUTES_BETWEEN_REFRESH minutes, then will do it now
if (now - lastCloseAllConnectionsTime > DateUtil.MINUTE * minutesBetweenRefresh) {
boolean isBalance = closeAllConnections();
if (isBalance == false) {
try {
// wait for the checked-out connections to be returned and closed
Thread.sleep(2000);
log.debug("DBUtils: sleep 2 seconds for checked-out connections to returned and closed.");
} catch (Exception ex) { }
}
}
Connection conection = null;
if (useDatasource) {
if (dataSource != null) {
conection = dataSource.getConnection();
}
} else {
if (connectionManager != null) {
conection = connectionManager.getConnection(maxTimeToWait);
} else {
log.fatal("Assertion: DBUtils.connectionManager == null");
}
}
if (conection == null) {
throw new SQLException("DBUtils: Cannot get connection from Connection Pool.");
}
return conection;
}
/**
* Close all the connections that currently in the pool
* This method could be used to refresh the database connection
* @return true if the pool is empty and balance
* false if the pool has returned some connection to outside
*/
public static boolean closeAllConnections() {
log.debug("DBUtils.closeAllConnections is called.");
boolean retValue = true;// balance (default)
lastCloseAllConnectionsTime = System.currentTimeMillis();
if (useDatasource) {
if (dataSource != null) {
// do nothing here now
}
} else {
if (connectionManager != null) {
retValue = connectionManager.release();
} else {
log.fatal("Assertion: DBUtils.connectionManager == null");
}
}
return retValue;
}
/**
* Use this method to return the connection to the connection pool
* Do not use this method to close connection that is not from
* the connection pool
* @param connection : the connection that needs to be returned to the pool
*/
public static void closeConnection(Connection connection) {
if (connection == null) return;
if (useDatasource) {
try {
connection.close();
} catch (SQLException e) {
log.error("DBUtils: Cannot close connection.", e);
}
} else {
connectionManager.freeConnection(connection);
}
}
/**
* Use this method to reset the MaxRows and FetchSize of the Statement
* to the default values
* @param statement : the statement that needs to be reseted
*/
public static void resetStatement(Statement statement) {
if (statement != null) {
try {
statement.setMaxRows(0); //reset to the default value
} catch (SQLException e) {
log.error("DBUtils: Cannot reset statement MaxRows.", e);
}
try {
statement.setFetchSize(0); //reset to the default value
} catch (SQLException sqle) {
//do nothing, postgreSQL doesnt support this method
}
}
}
/**
* Use this method to close the Statement
* @param statement : the statement that needs to be closed
*/
public static void closeStatement(Statement statement) {
try {
if (statement != null) statement.close();
} catch (SQLException e) {
log.error("DBUtils: Cannot close statement.", e);
}
}
/**
* Use this method to close the ResultSet
* @param rs : the resultset that needs to be closed
*/
public static void closeResultSet(ResultSet rs) {
try {
if (rs != null) rs.close();
} catch (SQLException e) {
log.error("DBUtils: Cannot close resultset.", e);
}
}
/*
public static void main(String[] args) {
//DBUtils DBUtils1 = new DBUtils();
//log.info("i = " + dataSource1);
}*/
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -