问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

如何在Java中执行Hive命令或HiveQL

发布网友 发布时间:2022-04-26 17:18

我来回答

2个回答

热心网友 时间:2022-04-07 17:46

Java在1.5过后提供了ProcessBuilder根据运行时环境启动一个Process调用执行运行时环境下的命令或应用程序(1.5以前使用Runtime),关于ProcessBuilder请参考Java相关文档。调用代码如下:
String sql="show tables; select * from test_tb limit 10";
List<String> command = new ArrayList<String>();
command.add("hive");
command.add("-e");
command.add(sql);
List<String> results = new ArrayList<String>();
ProcessBuilder hiveProcessBuilder = new ProcessBuilder(command);
hiveProcess = hiveProcessBuilder.start();
BufferedReader br = new BufferedReader(new InputStreamReader(
hiveProcess.getInputStream()));
String data = null;
while ((data = br.readLine()) != null) {
results.add(data);
}
其中command可以是其它Hive命令,不一定是HiveQL。

热心网友 时间:2022-04-07 19:04

java client 中hql执行跟数据库jdbc操作基本相同
1. maven工程依赖hive-jdbc相关jar包,其他工程类型参见maven repsository 相关依赖提示.

<dependency>

<groupId>org.apache.hive</groupId>

<artifactId>hive-jdbc</artifactId>

<version>2.1.0</version>

</dependency>
2. 书写相关代码,如果有链接池配置相关参数就好,注意链接池和hive-jdbc版本问题,过高的链接池版本配置hive-jdbc较低时,在连接校验时会出现unsupport异常.
// 加载驱动

Class.forName("org.apache.hive.jdbc.HiveDriver ");

// connection 为java.sql.Connection

Connection connection = DriverManager.getConnection("jdbc:hive2://locahost:10000/test");

// TODO:后续操作跟数据库jdbc操作一样,不要忘记关闭数据库连接.
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
我的硬盘给我格了 里面的照片 全没了 用什么软件能找回这些照片 我硬盘上的照片 莫名其妙 自己不在了 请问怎样恢复 谢谢。。。 ps改颜色底纹不变ps改颜色底纹不变色 不怕苦怎么造句 买电脑还是平板呢??? 笔记本电脑好还是微软平板电脑好 铁山靠TA是什么意思? 铁山靠求怕累是什么意思介绍_铁山靠求怕累是什么意思是什么 ...另有一盒质量不足,轻一些。至少称几次能保证找出这盒月饼... 9盒月饼中,有一盒质量不足,至少称()次能保证找出这盒月饼 A,2 B,3... 怎么测试hive jdbc连接 jdbc连接hiveserver2依赖哪些包 jdbc连接hive用什么sql语句 怎么通过hivejdbc停止hiveserver2的执行 如何获取hive jdbc打印的结果 hive jdbc连接不成功。。报错org.apache.thrift.transport.TTransport... HIVE JDBC 连接非default db hive jdbc执行出错,报MoveTask。求解 HiveJDBC如何获取当前SQL语句的表名 我微博没有给陌生人发过消息 但是每天都显示给陌生人发消息过多 所以发不了私信 我微博刚刚注册的 为 为什么认证的微博不能私信 今天开通新浪微博,私信怎么发不出去 使用手机号注册的微博,以前能给某人发私信,现在输入内容后按发送没有反应。请问是什么情况?谢谢! 年底找工作比较还是年初找工作比较好? 为什么90后找工作比00后难 为什么我微博发不了私信了?要验证码才能发,而且每条信息都是 双非毕业,找工作会比985和211学校毕业的人困难很多吗? 研究生找工作比本科生有多大优势? 应届生找工作比往届生有哪些优势,哪位高人指点一下? 为什么男人找工作要比女人难? sparkSQL用jdbc连接hive和用元数据连接hive的区别,各自优缺点?_百度... jdbc连接hive时怎么指定数据库啊?谢谢 hive只支持mysql数据库吗 如何用Hive访问Hadoop上数据 jdbc 访问hive 需要权限控制吗 hive2 jdbc session 超时 怎么自动重连 如何判断hive的远程服务接口已经打开 java中怎么实现查询出hive下所有数据库下表名 梦见蜂巢在衣服上有满满的蜂蜜? 梦见好多蜜蜂在我身上背部做窝 梦见蜂蜜沾衣是什么预兆 为什么要学LINUX? 我梦见好多蜜蜂飞在我身上? 梦见好多蜂蜜扎在自己屁股上了什么意思? 梦见身上落满了蜜蜂什么预兆? 周公解梦大全查询.梦到蜜蜂在我腿上筑巢 梦见很多蜂蜜掉在自己身上 梦见一瓢蜂蜜水到自己身上是什么意思 大家为什么要学习 Linux 梦见老公被蜂蜜包裹全身 很多蜜蜂围着他飞 是什么意思呢?