Go连接Hive

dazheng · · 8444 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

经过两天多的资料查找,反复测试从网上找到的多种方案,加上阿里云售后的支持,终于搞定Go语言连接Apache Hive的问题。
测试环境,阿里云E-MapReduce 2.1 中的Hive, Golang 1.7,开发环境win10。
在阿里云hive-site.xml中需要添加:

 <property>
    <name>hive.server2.authentication</name>
    <value>NOSASL</value>
  </property>

代码如下:

package main
import (
    "fmt"

    "github.com/derekgr/hivething"  //基于hiveserver2 thrift
)

func main() {
    db, err := hivething.Connect("${IP}:${port}", hivething.DefaultOptions)
    if err != nil {
        fmt.Errorf(err.Error())
    }
    defer db.Close()

    results, err := db.Query("show tables")  //select、dml、ddl都调用db.Query

    if err != nil {
        fmt.Println(err)
        return
    }

    var tableName string
    for results.Next() {
        results.Scan(&tableName)
        fmt.Println(tableName)
    }

有疑问加站长微信联系(非本文作者)

本文来自:CSDN博客

感谢作者:dazheng

查看原文:Go连接Hive

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

8444 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传