Go-ClickHouse 安装与使用指南

Go-ClickHouse 安装与使用指南

go-clickhouseGolang SQL database driver for Yandex ClickHouse项目地址:https://gitcode.com/gh_mirrors/go/go-clickhouse

1. 项目目录结构及介绍

Go-ClickHouse 库的目录结构通常遵循标准的 Go 项目布局:

go-clickhouse/
├── README.md       # 项目说明文档
├── cmd/             # 存放可执行程序的命令入口
│   └── example     # 示例应用代码
├── internal/        # 内部包,存放私有实现细节
│   ├── client       # ClickHouse 客户端实现
│   └── ...
├── pkg/             # 公共包,对外提供的功能
│   └── clickhouse   # Go-ClickHouse 包,包含了连接和操作 ClickHouse 的接口
├── testdata/        # 测试数据
└── tests/           # 测试代码
    └── integration  # 集成测试

cmd/example 目录下有一个简单的示例应用程序,可以用来了解如何集成和使用 Go-ClickHouse。

2. 项目的启动文件介绍

尽管 Go-ClickHouse 是一个库而非独立的应用,但你可以参考 cmd/example/main.go 文件来创建自己的程序。这是一个简单的启动点,演示了如何初始化连接并执行 SQL 查询:

package main

import (
	"fmt"
	"github.com/mailru/go-clickhouse"
)

func main() {
	conn, err := clickhouse.Open("http://localhost:8123/default")
	if err != nil {
		panic(err)
	}
	defer conn.Close()

Statement, err := conn.Prepare(`INSERT INTO test (name, value) VALUES (?, ?)`)
if err != nil {
    panic(err)
}

res, err := Statement.Exec("example", 123)
if err != nil {
    panic(err)
}

fmt.Println(res.RowsAffected())
}

此示例打开到本地 ClickHouse 实例的连接,并准备一个 INSERT 语句来写入数据。

3. 项目的配置文件介绍

Go-ClickHouse 本身并不直接使用配置文件,而是依赖于在代码中传递的连接字符串(DSN,Data Source Name)来配置连接。DSN 格式如下:

http[s]://[username:password@]host[:port]/[database]?[params]

例如,如果你的 ClickHouse 运行在 localhost 上的非默认端口,可能需要以下配置:

conn, err := clickhouse.Open("http://root:my_password@localhost:9000/my_database?debug=true")

其中,debug 参数是一个可选的查询参数,用于开启调试模式。其他可用的参数包括 timeout, read_timeout, write_timeout 等,具体可参考项目文档或源码。

请注意,实际使用中应确保安全性,避免明文密码出现在代码中,可以通过环境变量或其他安全方式管理认证凭证。

go-clickhouseGolang SQL database driver for Yandex ClickHouse项目地址:https://gitcode.com/gh_mirrors/go/go-clickhouse

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

尤辰城Agatha

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值