如何处理go代码查询XDB数据库的结果

如何处理go代码查询XDB数据库的结果,go,influxdb,Go,Influxdb,我正在从这样的go代码查询inlfluxdb数据库 q := fmt.Sprintf("select step,timeTaken from ZtpBoot where cvpVersion = 2017.1.1 group by step,numberOfDevices" res, _ := queryDB(clnt, q) Result when executing query in influxdb is like:- name: ZtpBoot ta

我正在从这样的go代码查询inlfluxdb数据库

q := fmt.Sprintf("select step,timeTaken from ZtpBoot where cvpVersion = 
                  2017.1.1 group by step,numberOfDevices"
res, _ := queryDB(clnt, q)
Result when executing query in influxdb is like:-
name: ZtpBoot
tags: numberOfDevices=2, step=Step3.verifyZtpViaPost
time                step                   timeTaken
----                ----                   ---------
1495540747000000000 Step3.verifyZtpViaPost 0.108520030975
1495541643000000000 Step3.verifyZtpViaPost 0.115226984024

name: ZtpBoot
tags: numberOfDevices=2, step=Step4.verifyZtpViaHttp
time                step                   timeTaken
----                ----                   ---------
1495540747000000000 Step4.verifyZtpViaHttp 0.100101947784
1495541643000000000 Step4.verifyZtpViaHttp 0.103901863098

我如何处理从res中获得的res,:=queryDB(clnt,q)以显示表中所示的结果。

如果仔细检查每种类型并总体上理解如何使用Go类型,则如何解析
res
中有

正如您在评论中所显示的,
res
是类型
[]client.Result
,这意味着它是结果的一部分。结果在文档中定义。查看结果中的每个字段,并查找它们的每个类型。如果他们对你来说没有意义,试着阅读更多关于Go中的类型含义的内容。考虑通过编写和运行一些以某种方式使用该类型的代码,再向前一步——创建它的文字并打印它,或者访问它的一部分,直到你习惯于使用它并更好地理解它。 查找文档中您不了解的任何部分,如Go中的符号
[]
(切片/数组)和
*
(指针)的含义,或者如果您还不确定切片和贴图在Go中是如何工作的,请查找这些内容。这是一个巨大的资源。若一段文档并没有意义,而您对它有更具体的问题,您可以向StackOverflow发布一个关于它的问题

我希望这个例子足以让你开始学习。如您所见,我使用不同类型的文本初始化了一些变量,然后运行与您在注释中运行的相同的print命令。请注意,它部分填充了您发布的结构

package main

import(
    "fmt"
    "github.com/influxdata/influxdb/client/v2"
    "github.com/influxdata/influxdb/models"
)

func main() {
    tags := map[string]string{
        "numberOfDevices":"1",
        "step":"Step1.dhcpSetupTime",
    }
    cols := []string{"time", "step", "timeTaken"}
    row := models.Row{
        Name: "ZtpBoot",
        Tags: tags,
        Columns: cols,
        // add Values and Partial
    }
    rows := []models.Row{row}
    res := client.Result{
        Series: rows,
        // Add Messages and Err
    }
    fmt.Printf("Res: %v\nType: %T\n", res, res)
}
该程序的输出为:

Res: {[{ZtpBoot map[numberOfDevices:1 step:Step1.dhcpSetupTime] [time step timeTaken] [] false}] [] }
Type: client.Result

我希望这足以让你朝着正确的方向开始。如果您研究它,看看我所做的,并阅读更多的Go文档,您可能能够填写其余部分,并了解如何访问此数据结构的部分。

是的,我查看了它,但无法获得我想要的输出:(.当您运行
fmt.Printf(“Res:%v\nType:%T\n”,Res,Res)时会得到什么
?我得到了这个->Res:[{{ZtpBoot map[设备数量:1步:Step1.dhcpSetupTime][2017-05-16T10:09:44Z Step1.dhcpSetupTime 0.560018062592][2017-05-16\T10:17:14Z Step1.dhcpSetupTime 0.893213033676][2017-05-16T10:24:44Z Step1.dhcpSetupTime 0.476826906204][2017-05-16T10:32:17Z Step1.dhcpSetupTime\488074][2017-05-16T10:42:39Z Step1.dhcpSetupTime 0.484630823135][2017-05-23T12:14:03Z totalRunTime 4\19.631438017]]false}][]}]类型:[]client.ResultSo如果不使用,那么client.Result类型在哪里定义?您使用的是不同的influxdb sql驱动程序吗?您自己定义的吗?client.Result类型是否有任何方法可以对其进行操作?我使用的是“github.com/influxdata/influxdb/client/v2”。有趣的是,精确性是如此完善,我能做些什么呢?“1e-3”?“1s”“s”?“TITI”?请不要再叫这个文档了,它是一个冒充文档的草率发布的网页。另一方面(我不喜欢C),
man 3 printf
是我称之为文档的东西