Class JDBCDataStoreFactory
- Object
- 
- JDBCDataStoreFactory
 
- 
- All Implemented Interfaces:
- DataAccessFactory,- DataStoreFactorySpi,- Factory
 - Direct Known Subclasses:
- AbstractDuckDBDataStoreFactory,- DB2NGDataStoreFactory,- GeoPkgDataStoreFactory,- H2DataStoreFactory,- H2GISDataStoreFactory,- HanaDataStoreFactory,- InformixDataStoreFactory,- JDBCJNDIDataStoreFactory,- MySQLDataStoreFactory,- OracleNGDataStoreFactory,- PostgisNGDataStoreFactory,- SingleStoreDataStoreFactory,- SQLServerDataStoreFactory,- TeradataDataStoreFactory
 
 public abstract class JDBCDataStoreFactory extends Object implements DataStoreFactorySpi Abstract implementation of DataStoreFactory for jdbc datastores.- Author:
- Justin Deoliveira, The Open Planning Project
 
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from interface DataAccessFactoryDataAccessFactory.Param
 
- 
 - 
Field SummaryFields Modifier and Type Field Description static DataAccessFactory.ParamBATCH_INSERT_SIZEIf different from one, the JDBCInsertFeatureWriter will buffer the features and insert them in batchesstatic DataAccessFactory.ParamCALLBACK_FACTORYJDBC callback factorystatic DataAccessFactory.ParamDATABASEparameter for database instancestatic DataAccessFactory.ParamDATASOURCEparameter for data sourcestatic DataAccessFactory.ParamDBTYPEparameter for database typestatic DataAccessFactory.ParamEVICTOR_TESTS_PER_RUNNumber of connections checked during a single evictor run *static DataAccessFactory.ParamEXPOSE_PKexpose primary key columns as attributesstatic DataAccessFactory.ParamFETCHSIZENumber of records readstatic DataAccessFactory.ParamHOSTparameter for database hoststatic DataAccessFactory.ParamMAX_OPEN_PREPARED_STATEMENTSNumber of prepared statements cached per connection (this param is exposed only by factories supporting prepared statements *static DataAccessFactory.ParamMAXCONNMaximum number of connections in the connection poolstatic DataAccessFactory.ParamMAXWAITMaximum amount of time the pool will wait when trying to grab a new connection *static DataAccessFactory.ParamMIN_EVICTABLE_TIMEMin time for a connection to be idle in order to be evicted *static DataAccessFactory.ParamMINCONNMinimum number of connections in the connection poolstatic DataAccessFactory.ParamNAMESPACEparameter for namespace of the datastorestatic DataAccessFactory.ParamPASSWDparameter for database passwordstatic DataAccessFactory.ParamPK_METADATA_TABLEMetadata table providing information about primary keys *static DataAccessFactory.ParamPORTparameter for database portstatic DataAccessFactory.ParamSCHEMAparameter for database schemastatic DataAccessFactory.ParamSQL_ON_BORROWSQL executed when the session beginsstatic DataAccessFactory.ParamSQL_ON_RELEASESQL executed when the session endsstatic DataAccessFactory.ParamTEST_WHILE_IDLEIf IDLE connections should be validated before using them *static DataAccessFactory.ParamTIME_BETWEEN_EVICTOR_RUNSIdle object evictor periodicity *static DataAccessFactory.ParamUSERparameter for database userstatic DataAccessFactory.ParamVALIDATECONNIf connections should be validated before using them
 - 
Constructor SummaryConstructors Constructor Description JDBCDataStoreFactory()
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description booleancanProcess(Map<String,?> params)Default implementation verifies the Map against the Param information.protected booleancheckDBType(Map<String,?> params)protected booleancheckDBType(Map<String,?> params, String dbtype)BasicDataSourcecreateDataSource(Map<String,?> params)DataSource access allowing SQL use: intended to allow client code to query available schemas.protected DataSourcecreateDataSource(Map<String,?> params, SQLDialect dialect)Creates the datasource for the data store.JDBCDataStorecreateDataStore(Map<String,?> params)Construct a live data source using the params specifed.protected JDBCDataStorecreateDataStoreInternal(JDBCDataStore dataStore, Map<String,?> params)Subclass hook to do additional initialization of a newly created datastore.DataStorecreateNewDataStore(Map<String,?> params)protected abstract SQLDialectcreateSQLDialect(JDBCDataStore dataStore)Creates the dialect that the datastore uses for communication with the underlying database.protected SQLDialectcreateSQLDialect(JDBCDataStore dataStore, Map<String,?> params)Creates the dialect that the datastore uses for communication with the underlying database.protected abstract StringgetDatabaseID()Returns a string to identify the type of the database.StringgetDisplayName()Name suitable for display to end user.protected abstract StringgetDriverClassName()Returns the fully qualified class name of the jdbc driver.Map<RenderingHints.Key,?>getImplementationHints()Returns the implementation hints for the datastore.protected StringgetJDBCUrl(Map<String,?> params)Builds up the JDBC url in a jdbc::// : / Override if you need a different setup DataAccessFactory.Param[]getParametersInfo()MetaData about the required Parameters (for createDataStore).protected abstract StringgetValidationQuery()Override this to return a good validation query (a very quick one, such as one that asks the database what time is it) or return null if the factory does not support validation.booleanisAvailable()Determines if the datastore is available.protected voidsetupParameters(Map<String,Object> parameters)Sets up the database connection parameters.- 
Methods inherited from class Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface DataAccessFactorygetDescription
 
- 
 
- 
- 
- 
Field Detail- 
DBTYPEpublic static final DataAccessFactory.Param DBTYPE parameter for database type
 - 
HOSTpublic static final DataAccessFactory.Param HOST parameter for database host
 - 
PORTpublic static final DataAccessFactory.Param PORT parameter for database port
 - 
DATABASEpublic static final DataAccessFactory.Param DATABASE parameter for database instance
 - 
SCHEMApublic static final DataAccessFactory.Param SCHEMA parameter for database schema
 - 
USERpublic static final DataAccessFactory.Param USER parameter for database user
 - 
PASSWDpublic static final DataAccessFactory.Param PASSWD parameter for database password
 - 
NAMESPACEpublic static final DataAccessFactory.Param NAMESPACE parameter for namespace of the datastore
 - 
DATASOURCEpublic static final DataAccessFactory.Param DATASOURCE parameter for data source
 - 
MAXCONNpublic static final DataAccessFactory.Param MAXCONN Maximum number of connections in the connection pool
 - 
MINCONNpublic static final DataAccessFactory.Param MINCONN Minimum number of connections in the connection pool
 - 
VALIDATECONNpublic static final DataAccessFactory.Param VALIDATECONN If connections should be validated before using them
 - 
FETCHSIZEpublic static final DataAccessFactory.Param FETCHSIZE Number of records read
 - 
BATCH_INSERT_SIZEpublic static final DataAccessFactory.Param BATCH_INSERT_SIZE If different from one, the JDBCInsertFeatureWriter will buffer the features and insert them in batches
 - 
MAXWAITpublic static final DataAccessFactory.Param MAXWAIT Maximum amount of time the pool will wait when trying to grab a new connection *
 - 
TEST_WHILE_IDLEpublic static final DataAccessFactory.Param TEST_WHILE_IDLE If IDLE connections should be validated before using them *
 - 
TIME_BETWEEN_EVICTOR_RUNSpublic static final DataAccessFactory.Param TIME_BETWEEN_EVICTOR_RUNS Idle object evictor periodicity *
 - 
MIN_EVICTABLE_TIMEpublic static final DataAccessFactory.Param MIN_EVICTABLE_TIME Min time for a connection to be idle in order to be evicted *
 - 
EVICTOR_TESTS_PER_RUNpublic static final DataAccessFactory.Param EVICTOR_TESTS_PER_RUN Number of connections checked during a single evictor run *
 - 
PK_METADATA_TABLEpublic static final DataAccessFactory.Param PK_METADATA_TABLE Metadata table providing information about primary keys *
 - 
MAX_OPEN_PREPARED_STATEMENTSpublic static final DataAccessFactory.Param MAX_OPEN_PREPARED_STATEMENTS Number of prepared statements cached per connection (this param is exposed only by factories supporting prepared statements *
 - 
EXPOSE_PKpublic static final DataAccessFactory.Param EXPOSE_PK expose primary key columns as attributes
 - 
SQL_ON_BORROWpublic static final DataAccessFactory.Param SQL_ON_BORROW SQL executed when the session begins
 - 
SQL_ON_RELEASEpublic static final DataAccessFactory.Param SQL_ON_RELEASE SQL executed when the session ends
 - 
CALLBACK_FACTORYpublic static final DataAccessFactory.Param CALLBACK_FACTORY JDBC callback factory
 
- 
 - 
Method Detail- 
getDisplayNamepublic String getDisplayName() Description copied from interface:DataAccessFactoryName suitable for display to end user.A non localized display name for this data store type. - Specified by:
- getDisplayNamein interface- DataAccessFactory
- Returns:
- A short name suitable for display in a user interface.
 
 - 
canProcesspublic boolean canProcess(Map<String,?> params) Default implementation verifies the Map against the Param information.It will ensure that: - params is not null
- Everything is of the correct type (or upcovertable to the correct type without Error)
- Required Parameters are present
 - Specified by:
- canProcessin interface- DataAccessFactory
- Parameters:
- params- The full set of information needed to construct a live data source.
- Returns:
- true if params is in agreement with getParametersInfo and checkDBType
 
 - 
createDataStorepublic final JDBCDataStore createDataStore(Map<String,?> params) throws IOException Description copied from interface:DataStoreFactorySpiConstruct a live data source using the params specifed.You can think of this as setting up a connection to the back end data source. Magic Params: the following params are magic and are honoured by convention by the GeoServer and uDig application. - "user": is taken to be the user name
- "passwd": is taken to be the password
- "namespace": is taken to be the namespace prefix (and will be kept in sync with GeoServer namespace management.
 - Specified by:
- createDataStorein interface- DataAccessFactory
- Specified by:
- createDataStorein interface- DataStoreFactorySpi
- Parameters:
- params- The full set of information needed to construct a live data store. Typical key values for the map include: url - location of a resource, used by file reading datasources. dbtype - the type of the database to connect to, e.g. postgis, mysql
- Returns:
- The created DataStore, this may be null if the required resource was not found or if insufficent parameters were given. Note that canProcess() should have returned false if the problem is to do with insuficent parameters.
- Throws:
- IOException- if there were any problems setting up (creating or connecting) the datasource.
 
 - 
createDataStoreInternalprotected JDBCDataStore createDataStoreInternal(JDBCDataStore dataStore, Map<String,?> params) throws IOException Subclass hook to do additional initialization of a newly created datastore.Typically subclasses will want to override this method in the case where they provide additional datastore parameters, those should be processed here. This method is provided with an instance of the datastore. In some cases subclasses may wish to create a new instance of the datastore, for instance in order to wrap the original instance. This is supported but the new datastore must be returned from this method. If not is such the case this method should still return the original passed in. - Parameters:
- dataStore- The newly created datastore.
- params- THe datastore parameters.
- Throws:
- IOException
 
 - 
createNewDataStorepublic DataStore createNewDataStore(Map<String,?> params) throws IOException - Specified by:
- createNewDataStorein interface- DataStoreFactorySpi
- Throws:
- IOException
 
 - 
getParametersInfopublic final DataAccessFactory.Param[] getParametersInfo() Description copied from interface:DataAccessFactoryMetaData about the required Parameters (for createDataStore).Interpretation of FeatureDescriptor values: - getDisplayName(): Gets the localized display name of this feature.
- getName(): Gets the programmatic name of this feature (used as the key in params)
- getShortDescription(): Gets the short description of this feature.
 This should be the same as: Object params = factory.getParameters(); BeanInfo info = getBeanInfo( params ); return info.getPropertyDescriptors();- Specified by:
- getParametersInfoin interface- DataAccessFactory
- Returns:
- Param array describing the Map for createDataStore
 
 - 
setupParametersprotected void setupParameters(Map<String,Object> parameters) Sets up the database connection parameters.Subclasses may extend, but should not override. This implementation registers the following parameters. Subclass implementation may remove any parameters from the map, or may overrwrite any parameters in the map.- Parameters:
- parameters- Map of- DataAccessFactory.Paramobjects.
 
 - 
isAvailablepublic boolean isAvailable() Determines if the datastore is available.Subclasses may with to override or extend this method. This implementation checks whether the jdbc driver class (provided by getDriverClassName()can be loaded.- Specified by:
- isAvailablein interface- DataAccessFactory
- Returns:
- true if and only if this factory has all the appropriate jars on the classpath to create DataStores.
 
 - 
getImplementationHintspublic Map<RenderingHints.Key,?> getImplementationHints() Returns the implementation hints for the datastore.Subclasses may override, this implementation returns null.- Specified by:
- getImplementationHintsin interface- Factory
- Returns:
- The map of hints, or an {@linkplain java.util.Collections.emptyMap() empty map} if none.
 
 - 
getDatabaseIDprotected abstract String getDatabaseID() Returns a string to identify the type of the database.Example: 'postgis'. 
 - 
getDriverClassNameprotected abstract String getDriverClassName() Returns the fully qualified class name of the jdbc driver.For example: org.postgresql.Driver 
 - 
createSQLDialectprotected SQLDialect createSQLDialect(JDBCDataStore dataStore, Map<String,?> params) Creates the dialect that the datastore uses for communication with the underlying database.- Parameters:
- dataStore- The datastore.
- params- The connection parameters
 
 - 
createSQLDialectprotected abstract SQLDialect createSQLDialect(JDBCDataStore dataStore) Creates the dialect that the datastore uses for communication with the underlying database.- Parameters:
- dataStore- The datastore.
 
 - 
createDataSourceprotected DataSource createDataSource(Map<String,?> params, SQLDialect dialect) throws IOException Creates the datasource for the data store.This method creates a BasicDataSourceinstance and populates it as follows:- poolPreparedStatements -> false
- driverClassName -> getDriverClassName()
- url -> 'jdbc:<getDatabaseID()>://<HOST>/<DATABASE>'
- username -> <USER>
- password -> <PASSWD>
 - Throws:
- IOException
 
 - 
createDataSourcepublic BasicDataSource createDataSource(Map<String,?> params) throws IOException DataSource access allowing SQL use: intended to allow client code to query available schemas.This DataSource is the clients responsibility to close() when they are finished using it. - Parameters:
- params- Map of connection parameter.
- Returns:
- DataSource for SQL use
- Throws:
- IOException
 
 - 
getValidationQueryprotected abstract String getValidationQuery() Override this to return a good validation query (a very quick one, such as one that asks the database what time is it) or return null if the factory does not support validation.
 - 
getJDBCUrlprotected String getJDBCUrl(Map<String,?> params) throws IOException Builds up the JDBC url in a jdbc::// : / Override if you need a different setup - Throws:
- IOException
 
 
- 
 
-