java impala_java操作hive和impala

本文介绍了如何在Java中通过Maven集成Hive和Impala JDBC驱动,并展示了它们的区别,主要关注于不同版本的对应和连接端口的配置。通过测试代码演示了如何执行SQL查询并获取结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

java 操作hive和impala

第一是maven加入jdbc库

org.apache.hive

hive-jdbc

1.1.0-cdh5.8.2

org.apache.hadoop

hadoop-common

2.7.3

注意:

hive-jdbc版本最好要跟impala版本对应上,否则会出现一些问题,比如我执行测试过程中碰到程序一直在运行,不出结果

cloudera repository

cloudera

https://repository.cloudera.com/artifactory/cloudera-repos/

测试代码:

package org.apache.zeppelin.impala;

import org.junit.Before;

import org.junit.BeforeClass;

import org.junit.Test;

import java.sql.*;

/**

* Created by moonx on 2016/9/29.

*/

public class ImpalaTest {

private static String driverName =

"org.apache.hive.jdbc.HiveDriver";

@Test

public void testHive() throws SQLException,ClassNotFoundException {

Class.forName(driverName);

Connection con = DriverManager.getConnection(

"jdbc:hive2://10.0.71.31:10000", "hive", "");

Statement stmt = con.createStatement();

String sql = "select * from test" ;

ResultSet res = stmt.executeQuery(sql);

while (res.next()) {

System.out.println(String.valueOf(res.getString(1)) + "\t"

+ res.getInt(2));

}

}

@Test

public void testImpala() throws SQLException,ClassNotFoundException{

Class.forName(driverName);

Connection con = DriverManager.getConnection(

"jdbc:hive2://10.0.71.31:21050/;auth=noSasl", "hive", "");

Statement stmt = con.createStatement();

String sql = "select * from test" ;

ResultSet res = stmt.executeQuery(sql);

while (res.next()) {

System.out.println(String.valueOf(res.getString(1)) + "\t"

+ res.getInt(2));

}

}

}

hive 和impala如何区分:

通过比较我们可以看到代码都是一样的,就是端口号不一样

hive用的10000,impala用的21050

就是这些区别

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值