• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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使用json格式实现增删查改的实现示例
    • golang json.Marshal 特殊html字符被转义的解决方法
    • golang结构体与json格式串实例代码
    • golang如何修改json文件内容的方法示例
    • Golang JSON的进阶用法实例讲解
    • golang如何自定义json序列化应用详解
    • golang json性能分析详解
    • golang中json反序列化可能遇到的问题
    • Golang map如何生成有序的json数据详解
    • 利用Golang解析json数据的方法示例
    • Golang中使用JSON的一些小技巧分享
    • Golang 如何解析和生成json
    上一篇:深入理解Go语言中的闭包
    下一篇:golang针对map的判断,删除操作示例
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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