All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.frameworkset.orm.adapter.DBFactory Maven / Gradle / Ivy

Go to download

bboss is a j2ee framework include aop/ioc,mvc,persistent,taglib,rpc,event ,bean-xml serializable and so on.http://www.bbossgroups.com

The newest version!
/*
 *  Copyright 2008 biaoping.yin
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.  
 */
package com.frameworkset.orm.adapter;



import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;

/**
 * This class creates different {@link com.frameworkset.orm.adapter.DB}
 * objects based on specified JDBC driver name.
 *
 * @author Frank Y. Kim
 * @author Jon S. Stevens
 * @author Brett McLaughlin
 * @author Ralf Stranzenbach
 * @author Daniel Rall
 * @author Henning P. Schmiedehausen
 * @version $Id: DBFactory.java,v 1.37 2005/01/31 19:43:55 tfischer Exp $
 */
public class DBFactory 
{
	private static Logger log = LoggerFactory.getLogger(DBFactory.class);
    /**
     * JDBC driver to Torque Adapter map.
     */

    private static Map adapters = java.util.Collections.synchronizedMap(new HashMap(40));

    public static final String  DBDB2400 = "as400";
    public static final String  DBDB2App = "db2app";
    public static final String  DBDB2Net = "db2net";
    public static final String  DBCloudscape = "cloudscape";
    public static final String  DBHypersonicSQL = "hypersonic";
    public static final String  DBInterbase = "interbase";
    public static final String  DBInstantDB =  "instantdb";
    public static final String  DBMSSQL = "mssql";
    public static final String  DBMMysql = "mysql";
    public static final String  DBMariaDB = "mariadb";
    public static final String  DBOracle = "oracle";
    public static final String  DBPostgres = "postgresql";
    public static final String  DBSapDB = "sapdb";
    public static final String  DBSybase = "sybase";
    public static final String  DBWeblogic = "weblogic";
    public static final String  DBAxion = "axion";
    public static final String  DBInformix = "informix";
    public static final String  DBOdbc = "odbc";
    public static final String  DBAccess = "msaccess";

    public static final String  DBDerby =  "derby";
    public static final String  DBHive =  "hive";

    public static final String  DBNone = "";
    public static final String  SQLITEX = "sqlitex";
    public static final String  DBTDEngine = "tdengine";
    public static final String  dm = "dm";
    public static final String  clickhouse = "clickhouse";
    public static final String  yandex_clickhouse = "yandex_clickhouse";
    public static final String  druid = "druid";
    public static final String  avatica = "avatica";
 

    

    /**
     * Initialize the JDBC driver to Torque Adapter map.
     * 
     */
    static
    {
    	
    	
        adapters.put("com.ibm.as400.access.AS400JDBCDriver", DBDB2400.class);
        adapters.put("COM.ibm.db2.jdbc.app.DB2Driver", DBDB2App.class);
        adapters.put("COM.ibm.db2.jdbc.net.DB2Driver", DBDB2Net.class);
        adapters.put("COM.cloudscape.core.JDBCDriver", DBCloudscape.class);
        adapters.put("org.hsql.jdbcDriver", DBHypersonicSQL.class);
        adapters.put("org.hsqldb.jdbcDriver", DBHypersonicSQL.class);
        adapters.put("interbase.interclient.Driver", DBInterbase.class);
        adapters.put("org.enhydra.instantdb.jdbc.idbDriver", DBInstantDB.class);
        adapters.put("com.microsoft.jdbc.sqlserver.SQLServerDriver",
            DBMSSQL.class);
        adapters.put("com.microsoft.sqlserver.jdbc.SQLServerDriver",
                     DBMSSQL.class);
        adapters.put("net.sourceforge.jtds.jdbc.Driver",
                DBMSSQL.class);
        
        
        adapters.put("com.jnetdirect.jsql.JSQLDriver", DBMSSQL.class);
        adapters.put("org.gjt.mm.mysql.Driver", DBMM.class);
        adapters.put("com.mysql.jdbc.Driver", DBMM.class);
		adapters.put("com.mysql.cj.jdbc.Driver", DBMM.class);
		adapters.put("org.elasticsearch.xpack.sql.jdbc.jdbc.JdbcDriver", DBElasticsearch.class);
		adapters.put("org.elasticsearch.xpack.sql.jdbc.EsDriver", DBElasticsearch.class);
		adapters.put("elasticsearch", DBElasticsearch.class);
        adapters.put("org.mariadb.jdbc.Driver", DBMariaDB.class);
        adapters.put("oracle.jdbc.driver.OracleDriver", DBOracle.class);
        adapters.put("oracle.jdbc.OracleDriver", DBOracle.class);
        adapters.put("org.postgresql.Driver", DBPostgres.class);
        adapters.put("com.sap.dbtech.jdbc.DriverSapDB", DBSapDB.class);
        adapters.put("com.sybase.jdbc.SybDriver", DBSybase.class);
        adapters.put("com.sybase.jdbc2.jdbc.SybDriver", DBSybase.class);
        adapters.put("weblogic.jdbc.pool.Driver", DBWeblogic.class);
        adapters.put("org.axiondb.jdbc.AxionDriver", DBAxion.class);
        adapters.put("com.informix.jdbc.IfxDriver", DBInformix.class);
        adapters.put("sun.jdbc.odbc.JdbcOdbcDriver", DBOdbc.class);

        adapters.put("com.ibm.db2.jcc.DB2Driver", DBDerby.class);
        adapters.put("org.apache.derby.jdbc.EmbeddedDriver", DBDerby.class);
        adapters.put("org.apache.derby.jdbc.ClientDriver", DBDerby.class);
		adapters.put("dm.jdbc.driver.DmDriver", DMAdaptor.class);

		adapters.put("com.github.housepower.jdbc.ClickHouseDriver", DBClickhouse.class);

        adapters.put("ru.yandex.clickhouse.ClickHouseDriver", DBYandexClickhouse.class);
        adapters.put("com.clickhouse.jdbc.ClickHouseDriver", DBYandexClickhouse.class);
       

        // add some short names to be used when drivers are not used
        adapters.put("as400", DBDB2400.class);        
        adapters.put("db2app", DBDB2App.class);
        adapters.put("db2net", DBDB2Net.class);
        adapters.put("cloudscape", DBCloudscape.class);
        adapters.put("hypersonic", DBHypersonicSQL.class);
        adapters.put("interbase", DBInterbase.class);
        adapters.put("instantdb", DBInstantDB.class);
        adapters.put("mssql", DBMSSQL.class);
        adapters.put("mysql", DBMM.class);
        adapters.put("mariadb", DBMariaDB.class);
        adapters.put("oracle", DBOracle.class);
        adapters.put("postgresql", DBPostgres.class);
        adapters.put("sapdb", DBSapDB.class);
        adapters.put("sybase", DBSybase.class);
        adapters.put("weblogic", DBWeblogic.class);
        adapters.put("axion", DBAxion.class);
        adapters.put("informix", DBInformix.class);
        adapters.put("odbc", DBOdbc.class);
        adapters.put("msaccess", DBOdbc.class);

        adapters.put("derby", DBDerby.class);
        adapters.put(SQLITEX, DBSQLiteXerial.class);
        adapters.put("org.sqlite.JDBC", DBSQLiteXerial.class);
        adapters.put("org.h2.Driver", DBH2.class);
        adapters.put("h2", DBH2.class);
        adapters.put("", DBNone.class);
        
        adapters.put("org.apache.hive.jdbc.HiveDriver", DBHive.class);
    	adapters.put(DBHive, DBHive.class);
		adapters.put("dm", DMAdaptor.class);
		adapters.put("clickhouse", DBClickhouse.class);
        adapters.put("yandex_clickhouse", DBYandexClickhouse.class);
        adapters.put("druid", DruidAdapter.class);
        adapters.put("avatica", DruidAdapter.class);
        adapters.put("org.apache.calcite.avatica.remote.Driver", DruidAdapter.class);

        adapters.put(DBTDEngine, DBTDEngine.class);
        adapters.put("com.taosdata.jdbc.TSDBDriver", DBTDEngine.class);

	}

    /**
     * Creates a new instance of the Torque database adapter associated
     * with the specified JDBC driver or adapter key.
     *
     * @param driver The fully-qualified name of the JDBC driver to
     * create a new adapter instance for or a shorter form adapter key.
     * @return An instance of a Torque database adapter.
     * @throws InstantiationException throws if the JDBC driver could not be
     *      instantiated
     */
    public static DB create(String driver)
        throws InstantiationException
    {
        if(driver == null || driver.trim().equals(""))
            driver = "";

        Class adapterClass =  adapters.get(driver);
		if(adapterClass == null) {

			adapterClass = adapters.get("");
			if(log.isWarnEnabled()){
				log.warn("Unknown JDBC driver: {}: Adapter DBNonewill be used or define one and resitry it to bboss.",driver);
			}
		}
        if (adapterClass != null)
        {
            try
            {
                DB adapter = (DB) adapterClass.newInstance();
                if(driver.indexOf(".") < 0)
                	adapter.setDbtype(driver);
                else
                {
                	adapter.setDbtype(lookupdbtype(adapterClass,driver));
                }
                // adapter.setJDBCDriver(driver);
                return adapter;
            }
            catch (IllegalAccessException e)
            {
                throw new InstantiationException(
                    "Could not instantiate adapter for JDBC driver: "
                    + driver
                    + ": Assure that adapter bytecodes are in your classpath");
            }
        }
        else
        {
            throw new InstantiationException(
                "Unknown JDBC driver: "
                + driver
                + ": Check your configuration file");
        }
    }
    private static String lookupdbtype(Class dbadaptor,String dbtype)
    {
    	Iterator> it = adapters.entrySet().iterator();
		while(it.hasNext())
		{
			Map.Entry entry = it.next();
			String key = entry.getKey();
			Class value = entry.getValue();
			
			if(dbadaptor == value)
			{
				
				if(key.indexOf(".") < 0)
					return key;
				
					
				
			}
			
		}
		return dbtype;
    }
    private static void replaceOthers(Class newclz,String newkey,Class defaultclazz)
    {
    	Iterator> it = adapters.entrySet().iterator();
		while(it.hasNext())
		{
			Map.Entry entry = it.next();
			String key = entry.getKey();
			Class value = entry.getValue();
			
			if(defaultclazz == value)
			{
				
				
				if(!newkey.equals(key))
				{
					log.debug("Use custom adapter["+newclz+"] to replace default adapter["+defaultclazz + "] for db[" + key+"]" );
					adapters.put(key, newclz);
				}
					
				
			}
			
		}
    }
    public static void addDBAdaptors(Map adaptors)
    {
    	if(adaptors == null || adaptors.size() == 0)
    	{
    		return ;
    	}
    	else
    	{
    		Iterator> it = adaptors.entrySet().iterator();
    		while(it.hasNext())
    		{
    			Map.Entry entry = it.next();
    			String key = entry.getKey();
    			String value = entry.getValue();
    			Class defaultclazz = adapters.get(key);
    			if(defaultclazz != null)
    			{
    				log.debug("Use custom adapter["+value+"] to replace default adapter["+defaultclazz + "] for db[" + key+"]" );
    				try {
						Class newclz = Class.forName(value);
						replaceOthers(newclz,key,defaultclazz);
						adapters.put(key, newclz);
						
					} catch (ClassNotFoundException e) {
						// TODO Auto-generated catch block
						e.printStackTrace();
					}
    			}
    			else
    			{
    				log.debug("Add custom adapter["+value+"] with db[" + key+"]" );
    				try {
						Class newclz = Class.forName(value);
						
						adapters.put(key, newclz);
						
					} catch (ClassNotFoundException e) {
						// TODO Auto-generated catch block
						e.printStackTrace();
					}
    			}
    			
    		}
    	}
    	
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy