当前位置: 首页 >Java技术 > 从零自学Hadoop(18):Hive的CLI和JDBC

从零自学Hadoop(18):Hive的CLI和JDBC

阅读目录

本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作。

文章是哥(mephisto)写的,SourceLink

 

     上一篇,我们对hive的数据导出,以及集群Hive数据的迁移进行描述。了解到了基本的hive导出操作。这里,我们将对hive的CLI及JDBC这些实用性很强的两个方便进行简要的介绍。

   下面我们开始介绍hive的CLI和JDBC。

Hive CLI(old CLI)

一:说明

  在0.11之前只有Hive CLI,他需要安装Hive Client才能使用。是一个重量级的命令行工具。连接的服务器是HiveServer1。

二:语法:

usage: hive -d,--define <key=value>  Variable subsitution to apply to hive  commands. e.g. -d A=B or --define A=B -e <quoted-query-string> SQL from command line -f <filename>SQL from files -H,--helpPrint help information -h <hostname>Connecting to Hive Server on remote host--hiveconf <property=value>Use value for given property--hivevar <key=value> Variable subsitution to apply to hive  commands. e.g. --hivevar A=B -i <filename>Initialization SQL file -p <port>Connecting to Hive Server on port number -S,--silent  Silent mode in interactive shell -v,--verbose Verbose mode (echo executed SQL to the  console)

三:官网例子1 

$HIVE_HOME/bin/hive -e 'select a.col from tab1 a'

四:官网例子2

  运行脚本文件

$HIVE_HOME/bin/hive -f /home/my/hive-script.sql

Beeline CLI(new CLI)

一:介绍

  为了使得CLI轻量化,后来Hive做出了Beeline和HiveServer2。Beeline是一个基于JDBC的SQLLine CLI。

二:官网例子

bin/beeline!connect jdbc:hive2://localhost:10000 scott tiger org.apache.hive.jdbc.HiveDriver

三:实战

  hiveserver2的默认端口是10000。

beeline -u jdbc:hive2://h188:10000

从零自学Hadoop(18):Hive的CLI和JDBC _ JavaClub全栈架构师技术笔记

   查看有哪些表。

show tables;
从零自学Hadoop(18):Hive的CLI和JDBC _ JavaClub全栈架构师技术笔记

 

  这里可以看到我们在上面几篇测试的时候的表score,score1,score2,我们查下score的数据。

select * from score;

从零自学Hadoop(18):Hive的CLI和JDBC _ JavaClub全栈架构师技术笔记

JDBC

一:介绍

  我们可以在代码中通过jdbc连接hive。这样在实际运用场景中就很方便,很原有的非分布式计算的开发方式基本类似,具有很强的适用性。

二:新建工程

  新建工程com.per.hive

三:引入包

  版本根据自己使用hadoop集群而定

commons-logging-1.2.jarhadoop-common-2.6.0.jarhive-exec-0.13.1.jarhive-jdbc-0.13.1.jarhive-service-0.13.1.jarhttpclient-4.3.4.jarhttpcore-4.3.2.jarlog4j-1.2.16.jarslf4j-api-1.7.6.jarslf4j-log4j12-1.7.6.jar

从零自学Hadoop(18):Hive的CLI和JDBC _ JavaClub全栈架构师技术笔记

四:添加类HiveDemo

从零自学Hadoop(18):Hive的CLI和JDBC _ JavaClub全栈架构师技术笔记

  添加HiveDriver

static {try {Class.forName("org.apache.hive.jdbc.HiveDriver");} catch (ClassNotFoundException ex) {ex.printStackTrace();}}

  添加test()方法

/** * @Description : 测试 */private static void test() {try (Connection con = DriverManager.getConnection("jdbc:hive2://h188:10000/")) {Statement stm = con.createStatement();ResultSet rs = stm.executeQuery("select * from score ");while (rs.next()) {String info = rs.getString(1);info += " " + rs.getString(2);info += " " + rs.getString(3);info += " " + rs.getString(4);System.out.println(info);}} catch (Exception ex) {ex.printStackTrace();}}

  调用

public static void main(String[] args) {test();}

从零自学Hadoop(18):Hive的CLI和JDBC _ JavaClub全栈架构师技术笔记

五:运行

  运行,查看结果,可以看见,程序运行的结果与我们在Beeline命令行查看的结果一致。

从零自学Hadoop(18):Hive的CLI和JDBC _ JavaClub全栈架构师技术笔记

  

 这样我们的Hive的CLI和JDBC告一段落。

 

--------------------------------------------------------------------

  到此,本章节的内容讲述完毕。

Demo下载

https://github.com/sinodzh/HadoopExample/tree/master/2016/com.per.hive

系列索引

  【源】从零自学Hadoop系列索引

 

 

 

 

本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作。

文章是哥(mephisto)写的,SourceLink

作者:sinodzh
来源链接:https://www.cnblogs.com/mephisto/p/5179786.html

版权声明:
1、JavaClub(https://www.javaclub.cn)以学习交流为目的,由作者投稿、网友推荐和小编整理收藏优秀的IT技术及相关内容,包括但不限于文字、图片、音频、视频、软件、程序等,其均来自互联网,本站不享有版权,版权归原作者所有。

2、本站提供的内容仅用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯相关权利人及本网站的合法权利。
3、本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站(javaclubcn@163.com),我们将第一时间核实后及时予以删除。





本文链接:https://www.javaclub.cn/java/117308.html

标签:JDBC
分享给朋友:

“从零自学Hadoop(18):Hive的CLI和JDBC” 的相关文章