Java 未找到适合jdbc:hsqldb:file:\dir\to\db的驱动程序
Java 未找到适合jdbc:hsqldb:file:\dir\to\db的驱动程序,java,database,spring,vaadin,hsqldb,Java,Database,Spring,Vaadin,Hsqldb,我想在我的Vaadin项目中使用HSQLDB,但它就是不起作用。我的连接代码如下所示: 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;
我想在我的Vaadin项目中使用HSQLDB,但它就是不起作用。我的连接代码如下所示:
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;
}
}
}
有人知道这个问题的解决办法吗?
非常感谢您启动了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“一个错误指示无法从类路径中找到类。在Maven中指定下载依赖项之后,您是否安装了下载依赖项?
no driver found
java.sql.SQLException: No suitable driver found for jdbc:hsqldb:file:D:\Dokumente\UNIWIDEDatabase
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;
}