我也是Hadoop和Hive的新手。我试图通过创建Java项目并添加以下所需的所有库来从Java连接到Hive
$HIVE_HOME/lib/*.jar
$HADOOP_HOME/share/hadoop/mapreduce/*.jar
$HADOOP_HOME/share/hadoop/common/*.jar
以下是我连接Hive数据库的示例代码。
package com.stpl.hive.jdbc;
import java.sql.SQLException;
import java.sql.Connection;
import java.sql.Statement;
import java.sql.DriverManager;
public class HiveSample {
//private static String driverName = "org.apache.hadoop.hive.jdbc.HiveDriver";
private static String driverName = "org.apache.hive.jdbc.HiveDriver";
public static void main(String[] args) throws SQLException,
ClassNotFoundException {
// Register driver and create driver instance
Class.forName(driverName);
// get connection
Connection con = DriverManager.getConnection(
"jdbc:hive2://localhost:10000/default", "", "");
Statement stmt = con.createStatement();
stmt.execute("CREATE DATABASE newdatabase");
System.out.println("Database userdb created successwdbfully.");
con.close();
}
}
在跑步时我的误差低于
Exception in thread "main" java.lang.NoClassDefFoundError: Could not initialize class org.apache.derby.jdbc.AutoloadedDriver40
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:348)
at java.sql.DriverManager.isDriverAllowed(DriverManager.java:556)
at java.sql.DriverManager.getConnection(DriverManager.java:661)
at java.sql.DriverManager.getConnection(DriverManager.java:247)
at com.stpl.hive.jdbc.HiveSample.main(HiveSample.java:18)
我是否遗漏了在项目中添加的任何其他罐子?请帮我解决这个错误。我正在使用Hive 2.3.2版本。请问我是否需要解决任何其他细节。
答案 0 :(得分:0)
java.lang.NoClassDefFoundError
在类的定义在运行时不存在时发生。
无法初始化类org.apache.derby.jdbc.AutoloadedDriver40
您似乎缺少德比的驱动程序库,可以通过包含derby-10.5.3.0.jar
来解决。