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

标签 postgresql go

我正在使用 github.com/jackc/pgx 来处理 postgreSQL。 Noq 我想将 pgx.Rows 从 Query() 转换为 json 数组。 我为 *sql.Rows 尝试了 func,但它对 *pgx.Rows

不起作用
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{},它仅适用于显式定义的类型。 你能帮我解决一下吗?

最佳答案

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

例如:

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
}

关于postgresql - 如何将 pgx.Rows 从 Query() 转换为 json 数组?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50238439/

相关文章:

HTTP 响应抛出错误 gzip : invalid header

go - 零指针嵌入错误

xml - 只定义一个结构并让它在 Go 中处理 XML 文件的所有内部元素?

sql - Postgres 中的 GROUP BY - JSON 数据类型不相等?

postgresql - Postgres 与 Docker : Postgres fails to load when persisting data

postgresql - 如何在postgresql中添加时间段,其中时间段有年、月、日?

postgresql - 无法加载驱动程序 org.postgresql 的模块

sql - 使用单个 SQL 命令更新表并显示更新的行

arrays - golang 中的全局数组

go - Go 中的 HTML 模板 - 插入 html 作为管道的值