Go Connector

linux环境

安装TDengine

Go的连接器使用到了 libtaos.so 和taos.h,因此,在使用Go连接器之前,需要在程序运行的机器上安装TDengine以获得相关的驱动文件。

Go语言引入package

TDengine提供了GO驱动程序“taosSql”包。taosSql驱动包是基于GO的“database/sql/driver”接口的实现。用户可以通过go get命令来获取驱动包。

  1. go get github.com/taosdata/TDengine/src/connector/go/src/taosSql

然后在应用程序中导入驱动包,就可以使用“database/sql”中定义的接口访问TDengine:

  1. import (
  2. "database/sql"
  3. _ "github.com/taosdata/TDengine/src/connector/go/src/taosSql"
  4. )

taosSql驱动包内采用cgo模式,调用了TDengine的C/C++同步接口,与TDengine进行交互,因此,在数据库操作执行完成之前,客户端应用将处于阻塞状态。单个数据库连接,在同一时刻只能有一个线程调用API。客户应用可以建立多个连接,进行多线程的数据写入或查询处理。

Go语言使用参考

在Go程序中使用TDengine写入方法大致可以分为以下几步

  1. 打开TDengine数据库链接

首先需要调用sql包中的Open方法,打开数据库,并获得db对象

  1. db, err := sql.Open(taosDriverName, dbuser+":"+dbpassword+"@/tcp("+daemonUrl+")/"+dbname)
  2. if err != nil {
  3. log.Fatalf("Open database error: %s\n", err)
  4. }
  5. defer db.Close()

其中参数为

  • taosDataname: 涛思数据库的名称,其值为字符串”taosSql”
  • dbuser和dbpassword: 链接TDengine的用户名和密码,缺省为root和taosdata,类型为字符串
  • daemonUrl: 为TDengine的地址,其形式为ip address:port形式,port填写缺省值0即可。例如:”116.118.24.71:0”
  • dbname:TDengine中的database名称,通过create database创建的数据库。如果为空则在后续的写入和查询操作必须通过”数据库名.超级表名或表名“的方式指定数据库名
  1. 创建数据库

打开TDengine数据库连接后,首选需要创建数据库。基本用法和直接在TDengine客户端shell下一样,通过create database + 数据库名的方法来创建。

  1. db, err := sql.Open(taosDriverName, dbuser+":"+dbpassword+"@/tcp("+daemonUrl+")/")
  2. if err != nil {
  3. log.Fatalf("Open database error: %s\n", err)
  4. }
  5. defer db.Close()
  6. //准备创建数据库语句
  7. sqlcmd := fmt.Sprintf("create database if not exists %s", dbname)
  8. //执行语句并检查错误
  9. _, err = db.Exec(sqlcmd)
  10. if err != nil {
  11. log.Fatalf("Create database error: %s\n", err)
  12. }
  1. 创建表、写入和查询数据

在创建好了数据库后,就可以开始创建表和写入查询数据了。这些操作的基本思路都是首先组装SQL语句,然后调用db.Exec执行,并检查错误信息和执行相应的处理。可以参考上面的样例代码。

windows环境

在windows上使用Go,请参考 TDengine GO windows驱动的编译和使用