Подтвердить что ты не робот

Вставка массива в базу данных Postgresql в Голанге

Я хочу, чтобы иметь возможность писать массив bigints в таблицу, которую я использую для истории в Go. К сожалению, я не могу и когда я делаю ошибку sql: converting Exec argument #1 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 ($1, $2, $3, $4)", rand.Int63(), t.productids, card.cid, t.salepoint);
}

Это структура таблицы, в которую я хочу вставить: tid bigint primary key, productids bigint[] not null, cardid bigint not null, salepoint int

4b9b3361

Ответ 1

Внедрить базу данных /sql/driver.Valuer с настраиваемым типом:

type int64array []int64

func (a int64array) Value() (driver.Value, error) {
    // Format a in PostgreSQL array input format {1,2,3} and return it as as string or []byte.
}

Ответ 2

Массивы поддерживаются в github.com/lib/pq с 2016 года 6 августа. Оператор OP может быть записан как:

_, err := db.Exec(
    "INSERT INTO history VALUES ($1, $2, $3, $4)", 
    rand.Int63(), 
    pq.Array(t.productids),   // <------- 
    card.cid, 
    t.salepoint,
)