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语言程序设计有所帮助。

声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#nhooo.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。