首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何将pgx.Rows从Query()转换为json数组?

如何将pgx.Rows从Query()转换为json数组?
EN

Stack Overflow用户
提问于 2018-05-08 16:36:38
回答 1查看 3.5K关注 0票数 7

我使用github.com/jackc/pgx与postgreSQL一起工作。Noq我希望将pgx.Rows从Query()转换为json数组。我试过*sql.Rows的func,但对*pgx.Rows不起作用

代码语言:javascript
复制
func PgSqlRowsToJson(rows *pgx.Rows) []byte {
   fieldDescriptions := rows.FieldDescriptions()
   var columns []string
   for _, col := range fieldDescriptions {
    columns = append(columns, col.Name)
   }

   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, _ := json.Marshal(tableData)

   return jsonData
}

问题是Scan()不适用于interface{},它只适用于显式定义的类型。你能帮我修一下吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-05-08 18:49:32

您可以使用pgx.FieldDescriptionType方法检索列的预期类型,然后将它传递给reflect.New,您可以分配一个指向该类型值的指针,然后使用这些新分配的值,您可以生成一个非零interface{}s的片段,其基础值具有预期类型。

例如:

代码语言:javascript
复制
func PgSqlRowsToJson(rows *pgx.Rows) []byte {
    fieldDescriptions := rows.FieldDescriptions()
    var columns []string
    for _, col := range fieldDescriptions {
        columns = append(columns, col.Name)
    }

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

    valuePtrs := make([]interface{}, count)
    for rows.Next() {
        for i := 0; i < count; i++ {
            valuePtrs[i] = reflect.New(fieldDescriptions[i].Type()).Interface() // allocate pointer to type
        }
        rows.Scan(valuePtrs...)

        entry := make(map[string]interface{})
        for i, col := range columns {
            var v interface{}
            val := reflect.ValueOf(valuePtrs[i]).Elem().Interface() // dereference pointer
            b, ok := val.([]byte)
            if ok {
                v = string(b)
            } else {
                v = val
            }
            entry[col] = v
        }
        tableData = append(tableData, entry)
    }
    jsonData, _ := json.Marshal(tableData)

    return jsonData
}
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50238439

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档