本文介紹了H2找不到適合JDBC的驅動程序:h2:Mem:的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!
問題描述
我正在嘗試一個使用H2的示例。但我無法創建內存中的數據庫。當我運行以下程序時,我只收到一條錯誤消息:
:找不到適用于JDBC:h2:Mem的驅動程序
Java.sql/java.sql.DriverManager.getConnection(DriverManager.java:702)
在…
Java.sql/java.sql.DriverManager.getConnection(DriverManager.java:251)
在DB.DBExample.main(DBExample.Java:14)
我包含在pom.xml中
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<version>1.4.200</version>
<scope>test</scope>
</dependency>
有人知道哪里出了問題嗎?
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.logging.Level;
import java.util.logging.Logger;
public class DBExample {
public static void main(String[] a) throws Exception {
var url = "jdbc:h2:mem:";
try (var con = DriverManager.getConnection(url);
var stm = con.createStatement();
var rs = stm.executeQuery("SELECT 1+1")) {
if (rs.next()) {
System.out.println(rs.getInt(1));
}
} catch (SQLException ex) {
var lgr = Logger.getLogger(DBExample.class.getName());
lgr.log(Level.SEVERE, ex.getMessage(), ex);
}
}
}
推薦答案
問題是因為您指定了<scope>test</scope>
。
刪除范圍行。
此作用域表示應用程序的正常使用不需要依賴項,并且僅在測試編譯和執行階段可用。
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<version>1.4.200</version>
</dependency>
查看此處:driver not found
這篇關于H2找不到適合JDBC的驅動程序:h2:Mem:的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,