H2 找不到适用于 jdbc:h2:mem 的驱动程序:

gef*_*fei 2 java h2

我正在尝试使用 H2 的示例。但我无法创建内存数据库。当我运行以下程序时,我只收到一条错误消息:

java.sql.SQLException:在 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>
Run Code Online (Sandbox Code Playgroud)

有人知道出了什么问题吗?

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);
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

Roh*_*h V 5

问题是因为你已经指定了<scope>test</scope>。删除范围线。

此范围表示应用程序的正常使用不需要该依赖项,并且仅在测试编译和执行阶段可用。

<dependency>
   <groupId>com.h2database</groupId>
   <artifactId>h2</artifactId>
   <version>1.4.200</version>
</dependency>
Run Code Online (Sandbox Code Playgroud)

看这里:找不到驱动程序