2 * Copyright (C) 2007 EDIT
3 * European Distributed Institute of Taxonomy
4 * http://www.e-taxonomy.eu
6 * The contents of this file are subject to the Mozilla Public License Version 1.1
7 * See LICENSE.TXT at the top of this package for the full license terms.
10 package eu
.etaxonomy
.cdm
.database
;
12 import java
.sql
.DatabaseMetaData
;
13 import java
.sql
.ResultSet
;
14 import java
.sql
.SQLException
;
16 import org
.hibernate
.cache
.CacheProvider
;
17 import org
.springframework
.beans
.factory
.config
.BeanDefinition
;
19 import eu
.etaxonomy
.cdm
.model
.name
.NomenclaturalCode
;
21 public interface ICdmDataSource
{
24 * Returns a BeanDefinition object of type DataSource that contains
25 * datsource properties (url, username, password, ...)
26 * @return BeanDefinition
28 public BeanDefinition
getDatasourceBean();
32 * @return BeanDefinition
34 public BeanDefinition
getHibernatePropertiesBean(DbSchemaValidation hbm2dll
);
40 * @param cacheProviderClass
41 * @return BeanDefinition
43 public BeanDefinition
getHibernatePropertiesBean(DbSchemaValidation hbm2dll
, Boolean showSql
, Boolean formatSql
, Boolean registerSearchListener
, Class
<?
extends CacheProvider
> cacheProviderClass
);
47 * The name representation of thie Datasource.
50 public String
getName();
56 public String
getServer();
61 public String
getDatabase();
63 public DatabaseTypeEnum
getDatabaseType();
73 public String
getFilePath();
78 public H2Mode
getMode();
81 * Tests, if a database connection can be established.
82 * @return true if test was successful, false otherwise
85 public boolean testConnection() throws DataSourceNotFoundException
;
87 public String
getUsername();
89 public String
getPassword();
92 * Executes a query and returns the ResultSet.
93 * @return ResultSet for the query.
95 public ResultSet
executeQuery (String query
);
101 public int executeUpdate (String sqlUpdate
);
103 public NomenclaturalCode
getNomenclaturalCode();
106 * Returns a single the first value of a row of a resultset.
108 * <strong>Caution</strong> This method opens a connection on first use. Subsequent calls will use the same connection.
109 * Please close the connection when not needed anymore with {@link ICdmDataSource#closeOpenConnections()}
113 * @throws SQLException
115 public Object
getSingleValue(String query
) throws SQLException
;
118 * Returns {@link DatabaseMetaData} for <code>this</code> datasource.
122 * <strong>Caution</strong> This method opens a connection that should be closed
123 * with {@link #closeOpenConnections()}
127 public DatabaseMetaData
getMetaData();
132 public void closeOpenConnections();
135 // public void setFilePath(String filePath);
137 // public void setMode(H2Mode mode);