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

com.foundationdb.sql.jdbc.Driver Maven / Gradle / Ivy

There is a newer version: 2.1-0-jdbc41
Show newest version
/*-------------------------------------------------------------------------
*
* Copyright (c) 2003-2011, PostgreSQL Global Development Group
*
*
*-------------------------------------------------------------------------
*/
package com.foundationdb.sql.jdbc;

import java.sql.*;
import java.util.*;

import com.foundationdb.sql.jdbc.util.PSQLState;
import com.foundationdb.sql.jdbc.util.PSQLDriverVersion;
import com.foundationdb.sql.jdbc.util.GT;

/**
 * The Java SQL framework allows for multiple database drivers.  Each
 * driver should supply a class that implements the Driver interface
 *
 * 

The DriverManager will try to load as many drivers as it can find and * then for any given connection request, it will ask each driver in turn * to try to connect to the target URL. * *

It is strongly recommended that each Driver class should be small and * stand alone so that the Driver class can be loaded and queried without * bringing in vast quantities of supporting code. * *

When a Driver class is loaded, it should create an instance of itself * and register it with the DriverManager. This means that a user can load * and register a driver by doing Class.forName("foo.bah.Driver") * * @see com.foundationdb.sql.jdbc.PGConnection * @see java.sql.Driver */ public class Driver extends com.foundationdb.sql.jdbc.DriverBase { static { try { // moved the registerDriver from the constructor to here // because some clients call the driver themselves (I know, as // my early jdbc work did - and that was based on other examples). // Placing it here, means that the driver is registered once only. java.sql.DriverManager.registerDriver(new Driver()); } catch (SQLException e) { e.printStackTrace(); } } /** * Create a connection from URL and properties. Always * does the connection work in the current thread without * enforcing a timeout, regardless of any timeout specified * in the properties. * * @param url the original URL * @param props the parsed/defaulted connection properties * @return a new connection * @throws SQLException if the connection could not be made */ protected Connection makeConnection(String url, Properties props) throws SQLException { Properties p = new Properties (props); p.setProperty("PROTOCOL", getProtocol()); p.setProperty("VERSION", getVersion()); p.setProperty("MAJORVERSION", Integer.toString(getMajorVersion())); p.setProperty("MINORVERSION", Integer.toString(getMinorVersion())); return new com.foundationdb.sql.jdbc.jdbc4.Jdbc4Connection(hostSpecs(p), user(p), database(p), p, url); } public static final int MAJORVERSION = 2; /** * Gets the drivers major version number * * @return the drivers major version number */ public int getMajorVersion() { return MAJORVERSION; } public static final int MINORVERSION = 1; /** * Get the drivers minor version number * * @return the drivers minor version number */ public int getMinorVersion() { return MINORVERSION; } /** * Returns the server version series of this driver and the * specific build number. */ public static String getVersion() { return "FoundationDB SQL layer 2.1 JDBC4 (build " + PSQLDriverVersion.buildNumber + ")"; } public String getProtocol() { return "jdbc:fdbsql:"; } protected String getName() { return "FoundationBD SQL layer"; } protected String getResourcesName() { return "org/fdbsql/driverconfig.properties"; } protected String getPortNumber() { return "15432"; } /* * This method was added in v6.5, and simply throws an SQLException * for an unimplemented method. I decided to do it this way while * implementing the JDBC2 extensions to JDBC, as it should help keep the * overall driver size down. * It now requires the call Class and the function name to help when the * driver is used with closed software that don't report the stack trace * @param callClass the call Class * @param functionName the name of the unimplemented function with the type * of its arguments * @return PSQLException with a localized message giving the complete * description of the unimplemented function */ public static java.sql.SQLFeatureNotSupportedException notImplemented(Class callClass, String functionName) { return new java.sql.SQLFeatureNotSupportedException(GT.tr("Method {0} is not yet implemented.", callClass.getName() + "." + functionName), PSQLState.NOT_IMPLEMENTED.getState()); } public java.util.logging.Logger getParentLogger() throws java.sql.SQLFeatureNotSupportedException { throw notImplemented(this.getClass(), "getParentLogger()"); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy