PostgreSQL
 sql >> Database >  >> RDS >> PostgreSQL

panic:sql:previsto 1 argomento di destinazione in Scan, non golang, pq, sql

La query restituisce un campo per riga. Il codice sta scansionando per tre. Forse vuoi qualcosa come:

err := db.QueryRow("SELECT data->>'id', data->>'type', data->>'title' FROM message WHERE data->>'id'=$1", id).Scan(m.Id, m.Type, m.Title)

Inoltre, passa i puntatori ai valori:

err := db.QueryRow("SELECT data->>'id', data->>'type', data->>'title' FROM message WHERE data->>'id'=$1", id).Scan(&m.Id, &m.Type, &m.Title)

Un'altra opzione è recuperare i dati come un singolo campo e decodificare il risultato con il pacchetto encoding/json.

var p []byte
err := db.QueryRow("SELECT data FROM message WHERE data->>'id'=$1", id).Scan(&p)
if err != nil {
    // handle error
}
var m Message
err := json.Unmarshal(p, &m)
if err != nil {
    // handle error
}