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

nz.co.gregs.dbvolution.databases.JavaDBMemoryDB Maven / Gradle / Ivy

/*
 * Copyright 2014 gregory.graham.
 *
 * 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 nz.co.gregs.dbvolution.databases;

import java.sql.SQLException;
import java.sql.Statement;
import javax.sql.DataSource;
import nz.co.gregs.dbvolution.databases.definitions.JavaDBMemoryDBDefinition;
import nz.co.gregs.dbvolution.exceptions.UnableToCreateDatabaseConnectionException;
import nz.co.gregs.dbvolution.exceptions.UnableToFindJDBCDriver;

/**
 * Use this class to work with an in-memory JavaDB.
 *
 * 

Support DBvolution at * Patreon

* * @author gregory.graham */ public class JavaDBMemoryDB extends DBDatabase { public static final long serialVersionUID = 1l; private static final String DRIVER_NAME = "org.apache.derby.jdbc.ClientDriver"; /** * Default Constructor. * */ public JavaDBMemoryDB() { } /** * Creates a new JavaDB instance that will connect to the DataSource. * * @param dataSource dataSource */ public JavaDBMemoryDB(DataSource dataSource) { super(new JavaDBMemoryDBDefinition(), dataSource); } /** * Creates a new JavaDB instance that will connect to the JDBC URL using the * username and password supplied.. * * @param jdbcURL jdbcURL * @param username username * @param password password */ public JavaDBMemoryDB(String jdbcURL, String username, String password) { super(new JavaDBMemoryDBDefinition(), DRIVER_NAME, jdbcURL, username, password); } /** * Creates or connects to a JavaDB in-memory instance. * * @param host host * @param username username * @param port port * @param database database * @param password password * @throws java.sql.SQLException java.sql.SQLException */ public JavaDBMemoryDB(String host, int port, String database, String username, String password) throws SQLException, UnableToCreateDatabaseConnectionException, UnableToFindJDBCDriver { super(new JavaDBMemoryDBDefinition(), DRIVER_NAME, "jdbc:derby://" + host + ":" + port + "/memory:" + database + ";create=true", username, password); } @Override public JavaDBMemoryDB clone() throws CloneNotSupportedException { return (JavaDBMemoryDB) super.clone(); //To change body of generated methods, choose Tools | Templates. } @Override protected void addDatabaseSpecificFeatures(Statement statement) throws SQLException { ; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy