首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在clickhouse中用一个命令插入csv文件

如何在clickhouse中用一个命令插入csv文件
EN

Stack Overflow用户
提问于 2021-12-20 11:34:57
回答 1查看 612关注 0票数 0

是否有一种方法可以在一个命令中使用这个go库https://github.com/ClickHouse/clickhouse-go插入csv文件(不需要读取csv并迭代内容)。如果有办法,你能给我举个例子吗?否则,如何使用os/exec库将系统命令转换为golang。cat /home/srijan/employee.csv \ clickhouse-client -query=“插入test1格式CSV”

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-12-20 13:37:23

有那个围棋图书馆是不可能的。您可以使用http api https://clickhouse.com/docs/en/interfaces/http/和任何http go客户端。

例如

代码语言:javascript
运行
复制
package main

import (
        "compress/gzip"
        "fmt"
        "io"
        "io/ioutil"
        "net/http"
        "net/url"
        "os"
)

func compress(data io.Reader) io.Reader {
        pr, pw := io.Pipe()
        gw, err := gzip.NewWriterLevel(pw, int(3))
        if err != nil {
                panic(err)
        }

        go func() {
                _, _ = io.Copy(gw, data)
                gw.Close()
                pw.Close()
        }()

        return pr
}

func main() {
        p, err := url.Parse("http://localhost:8123/")
        if err != nil {
                panic(err)
        }
        q := p.Query()

        q.Set("query", "INSERT INTO test1 FORMAT CSV")
        p.RawQuery = q.Encode()
        queryUrl := p.String()

        var req *http.Request


        req, err = http.NewRequest("POST", queryUrl, compress(os.Stdin))
        req.Header.Add("Content-Encoding", "gzip")

        if err != nil {
                panic(err)
        }

        client := &http.Client{
                Transport: &http.Transport{DisableKeepAlives: true},
        }
        resp, err := client.Do(req)
        if err != nil {
                panic(err)
        }
        defer resp.Body.Close()

        body, _ := ioutil.ReadAll(resp.Body)

        if resp.StatusCode != 200 {
                panic(fmt.Errorf("clickhouse response status %d: %s", resp.StatusCode, string(body)))
        }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70421191

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档