• 手动新建hive编程环境(以hive-1.0.0和hive-1.2.1为例)


      如下,是用maven构建项目,本篇博文重点不是这个。初学者(小白)变成小鸟后,建议开始用maven啦!

    Eclipse下Maven新建项目、自动打依赖jar包(包含普通项目和Web项目)

    HBase 开发环境搭建(EclipseMyEclipse + Maven)

    MapReduce 开发环境搭建(EclipseMyEclipse + Maven)

    Hadoop项目开发环境搭建(EclipseMyEclipse + Maven)

    Hive项目开发环境搭建(EclipseMyEclipse + Maven)

      对于初学者,比如在Eclipse/MyEclipse里,手动构建hive项目来编程。怎么做呢?如下

      第一步:

       第二步:这里,你要么可以跟我这样,直接选择Map/Reduce project(这里可以直接把hadoop所有jar包导入,因为编程中你还是要用到hdfs啦。)

      第三步:给你的Hive项目取名。

      第四步:

      第五步:得到

      第六步:编个入门程序

    Demo.java
     1 package com.dajangtai.Hive;
     2 
     3 
     4 
     5 
     6 import java.sql.Connection;
     7 import java.sql.DriverManager;
     8 import java.sql.ResultSet;
     9 import java.sql.SQLException;
    10 import java.sql.Statement;
    11 
    12 
    13 public class Demo {
    14     private static String driverName = "org.apache.hive.jdbc.HiveDriver";//hive驱动名称
    15     private static String url = "jdbc:hive2://djt002:10000/default";//连接hive2服务的连接地址,Hive0.11.0以上版本提供了一个全新的服务:HiveServer2
    16     private static String user = "hadoop";//对HDFS有操作权限的用户
    17     private static String password = "";//在非安全模式下,指定一个用户运行查询,忽略密码
    18     private static String sql = "";
    19     private static ResultSet res;
    20     public static void main(String[] args) {
    21         try {
    22             Class.forName(driverName);//加载HiveServer2驱动程序
    23             Connection conn = DriverManager.getConnection(url, user, password);//根据URL连接指定的数据库
    24             Statement stmt = conn.createStatement();
    25             
    26             //创建的表名
    27             String tableName = "testHiveDriverTable";
    28             
    29             /** 第一步:表存在就先删除 **/
    30             sql = "drop table " + tableName;
    31             stmt.execute(sql);
    32             
    33             /** 第二步:表不存在就创建 **/
    34             sql = "create table " + tableName + " (key int, value string)  row format delimited fields terminated by '	' STORED AS TEXTFILE";
    35             stmt.execute(sql);
    36             
    37             // 执行“show tables”操作
    38             sql = "show tables '" + tableName + "'";
    39             res = stmt.executeQuery(sql);
    40             if (res.next()) {
    41                 System.out.println(res.getString(1));
    42             }
    43             
    44             // 执行“describe table”操作
    45             sql = "describe " + tableName;
    46             res = stmt.executeQuery(sql);
    47             while (res.next()) {  
    48                 System.out.println(res.getString(1) + "	" + res.getString(2));
    49             }
    50             
    51             // 执行“load data into table”操作
    52             String filepath = "/usr/local/data/djt.txt";//hive服务所在节点的本地文件路径
    53             sql = "load data local inpath '" + filepath + "' into table " + tableName;
    54             stmt.execute(sql);
    55             
    56             // 执行“select * query”操作
    57             sql = "select * from " + tableName;
    58             res = stmt.executeQuery(sql);
    59             while (res.next()) {
    60                 System.out.println(res.getInt(1) + "	" + res.getString(2));
    61             }
    62             
    63             // 执行“regular hive query”操作,此查询会转换为MapReduce程序来处理
    64             sql = "select count(*) from " + tableName;
    65             res = stmt.executeQuery(sql);
    66             while (res.next()) {
    67                 System.out.println(res.getString(1));
    68             }        
    69             conn.close();
    70             conn = null;
    71         } catch (ClassNotFoundException e) {
    72             e.printStackTrace();
    73             System.exit(1);
    74         } catch (SQLException e) {
    75             e.printStackTrace();
    76             System.exit(1);
    77         }
    78     }
    79 }

     

       运行之后,得到

    2 hive的使用 + hive的常用语法

  • 相关阅读:
    IOS 使用CoreText实现表情文本URL等混合显示控件
    IOS 正则表达式匹配文本中URL位置并获取URL所在位置(解决连接中文问题)
    IOS 多级列表展开控件
    IOS 五星评分控件
    ios实现类似魔兽小地图功能 在
    Cocoa Foundation框架学习笔记 - NSCalendar
    lua通过bunlde读注意事项
    unity手游之聊天SDK集成与使用二
    unity手游之聊天SDK集成与使用一
    unity3d引擎程序员养成
  • 原文地址:https://www.cnblogs.com/zlslch/p/6560457.html
Copyright © 2020-2023  润新知