我是Hadoop和生态系统的新手。我正在用Java的JDBC尝试Hive。
这是我的简单代码,仅用于测试驱动程序:
import java.sql.DriverManager;
import java.sql.SQLException;
public class PrepareHiveTable {
private static String driverName = "org.apache.hive.jdbc.HiveDriver";
public static void main(String[] args) throws ClassNotFoundException, SQLException {
Class.forName(driverName);
Connection con = DriverManager.getConnection("jdbc:hive://localhost:10000/default", "", "");
}
}
我已将
org.apache.hive.jdbc.HiveDriver
导入到类路径中,这是我的DriverManager
上的驱动程序列表:org.apache.calcite.avatica.remote.Driver@45ff54e6
org.apache.calcite.jdbc.Driver@3581c5f3
org.apache.derby.jdbc.AutoloadedDriver40@4f8e5cde
com.mysql.jdbc.Driver@6f75e721
org.apache.hive.jdbc.HiveDriver@69222c14
但是,当我运行代码时,出现此错误:
Exception in thread "main" java.sql.SQLException: No suitable driver found for
jdbc:hive://localhost:10000/default
at java.sql.DriverManager.getConnection(DriverManager.java:689)
at java.sql.DriverManager.getConnection(DriverManager.java:247)
at PrepareHiveTable.main(PrepareHiveTable.java:24)
Java Result: 1
这里有人知道怎么回事吗?以及如何解决呢?
最佳答案
我找到了解决方案。我使用 hive 1.2.1,所以我需要写jdbc:hive2://localhost:10000/default
而不是jdbc:hive://localhost:10000/default
谢谢你