Вставка массива в базу данных Postgresql в Golang
Я хочу иметь возможность записать массив bigints в таблицу, которую я использую для истории в Go. К сожалению, я не могу и когда я делаю ошибку sql: converting Exec argument #1's type: unsupported type []int64, a slice
бросается. Вот что я делаю, отредактировано для краткости:
type Card struct {
cid int64
}
type Transaction struct {
tid, cardid int64
productids []int64
salepoint int
cardkey string
}
func logPurchase(card *Card, t *Transaction) {
_, err := db.Exec("INSERT INTO history VALUES (, , , )", rand.Int63(), t.productids, card.cid, t.salepoint);
}
Это структура таблицы, которую я хочу вставить в:
tid bigint primary key, productids bigint[] not null, cardid bigint not null, salepoint int
2 ответов
реализовать database / sql / driver.Оценщик с пользовательским типом:
type int64array []int64
func (a int64array) Value() (driver.Value, error) {
// Format a in PostgreSQL's array input format {1,2,3} and return it as as string or []byte.
}
массивы поддерживаются в github.com/lib/pq
С 2016 августа 6th. Заявление ОП может быть написано как:
_, err := db.Exec(
"INSERT INTO history VALUES (, , , )",
rand.Int63(),
pq.Array(t.productids), // <-------
card.cid,
t.salepoint,
)