Не найден подходящий драйвер для jdbc: hsqldb: file: \ dir \ to \ db - PullRequest
0 голосов
/ 06 октября 2019


Я хочу использовать HSQLDB в моем Vaadin-Project, но он просто не работает. Код для моего подключения выглядит так:

package ml.uniwide.ufin.spring;
import java.sql.*;

public class MySQL { // I know that I use HSQLDB not MySQL...
    public boolean auth(String username, String password) {
        Connection conn = null;
        try {
              Class.forName( "org.hsqldb.jdbcDriver" );
            }
            catch ( ClassNotFoundException e ) {
              System.err.println( "no driver found" );
            }
        String url = "jdbc:hsqldb:file:D:\\Dokumente\\UNIWIDEDatabase";
        try {
            Connection con = DriverManager.getConnection( url, "user", "pw" );

            Statement stmt = con.createStatement();
            String selectUserName = "SELECT * FROM \"PUBLIC\".\"USERS\" WHERE USERNAME = '" + username + "' AND PASSWORDHASH = '" + password + "'";
            ResultSet result = stmt.executeQuery(selectUserName);
            int count = 0;
            while(result.next()) {
                count++;
            }
            if(count<1) {
                return false;
            } else {
                return true;
            }
        } catch (SQLException e) {
            e.printStackTrace();
            return false;
        }
    }
}

И я также добавил в файл pom.xml:

<dependency>
    <groupId>org.hsqldb</groupId>
    <artifactId>hsqldb</artifactId>
    <version>2.5.0</version>
</dependency>

Я также попытался включить внешний файл hsqldb.jar вЗатмение, но вывод всегда:

no driver found
java.sql.SQLException: No suitable driver found for jdbc:hsqldb:file:D:\Dokumente\UNIWIDEDatabase

Кто-нибудь знает решение этой проблемы? Большое спасибо

1 Ответ

0 голосов
/ 06 октября 2019

Вы запустили сервис HSQLDB? Перед установлением какого-либо соединения его необходимо запустить с помощью инструментов менеджера или программным способом с помощью некоторого кода, подобного следующему:

public class DBManager {

final String dbLocation = "D:\\Dokumente\\UNIWIDEDatabase"; // change it to your db location
org.hsqldb.Server sonicServer;
Connection dbConn = null;

public static void main(String[] args) {
    DBManager manager = new DBManager();
    manager.startDBServer();
}

public void startDBServer() {
    HsqlProperties props = new HsqlProperties();
    props.setProperty("server.database.0", "file:" + dbLocation + ";");
    props.setProperty("server.dbname.0", "xdb");
    sonicServer = new org.hsqldb.Server();
    try {
        sonicServer.setProperties(props);
    } catch (Exception e) {
        return;
    }
    sonicServer.start();
}

public void stopDBServer() {
    sonicServer.shutdown();
}

public Connection getDBConn() {
    try {
        Class.forName("org.hsqldb.jdbcDriver");
        dbConn = DriverManager.getConnection(
                "jdbc:hsqldb:hsql://localhost/xdb", "SA", "");
    } catch (Exception e) {
        e.printStackTrace();
    }
    return dbConn;
}

}, а затем URL, с которым вы соединяетесь, будет иметь вид "jdbc:hsqldb:hsql://localhost/xdb"

...