华域联盟 Golang golang实现sql结果集以json格式输出的方法

golang实现sql结果集以json格式输出的方法

本文实例讲述了golang实现sql结果集以json格式输出的方法。分享给大家供大家参考,具体如下:

复制代码 代码如下: func getJSON(sqlString string) (string, error) {

    stmt, err := db.Prepare(sqlString)

    if err != nil {

        return nil, err

    }

    defer stmt.Close()

    rows, err := stmt.Query()

    if err != nil {

        return nil, err

    }

    defer rows.Close()

    columns, err := rows.Columns()

    if err != nil {

      return "", err

    }

    count := len(columns)

    tableData := make([]map[string]interface{}, 0)

    values := make([]interface{}, count)

    valuePtrs := make([]interface{}, count)

    for rows.Next() {

      for i := 0; i < count; i++ {

          valuePtrs[i] = &values[i]
      }

      rows.Scan(valuePtrs...)

      entry := make(map[string]interface{})

      for i, col := range columns {

          var v interface{}

          val := values[i]
          b, ok := val.([]byte)

          if ok {

              v = string(b)

          } else {

              v = val

          }

          entry[col] = v

      }

      tableData = append(tableData, entry)

    }

    jsonData, err := json.Marshal(tableData)

    if err != nil {

      return "", err

    }

    fmt.Println(string(jsonData))

    return string(jsonData), nil

}

PS:关于json操作,这里再为大家推荐几款比较实用的json在线工具供大家参考使用:

在线JSON代码检验、检验、美化、格式化工具:
http://tools.jb51.net/code/json

JSON在线格式化工具:
http://tools.jb51.net/code/jsonformat

在线XML/JSON互相转换工具:
http://tools.jb51.net/code/xmljson

json代码在线格式化/美化/压缩/编辑/转换工具:
http://tools.jb51.net/code/jsoncodeformat

在线json压缩/转义工具:
http://tools.jb51.net/code/json_yasuo_trans

C语言风格/HTML/CSS/json代码格式化美化工具:
http://tools.jb51.net/code/ccode_html_css_json

希望本文所述对大家Go语言程序设计有所帮助。

本文由 华域联盟 原创撰写:华域联盟 » golang实现sql结果集以json格式输出的方法

转载请保留出处和原文链接:https://www.cnhackhy.com/110198.htm

本文来自网络,不代表华域联盟立场,转载请注明出处。

作者: sterben

深入理解Go语言中的闭包

Win7环境下搭建Go开发环境(基于VSCode编辑器)

发表回复

联系我们

联系我们

2551209778

在线咨询: QQ交谈

邮箱: [email protected]

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们