Я пытаюсь сохранить массив чисел в одном поле postgresql, используя Gorm.
Массив должен быть списком от 2 до 13 чисел: [1, 2, 3, 5 , 8, 13, 21, 40, 1000]
Все работало при сохранении одного int64. Когда я попытался изменить модель для учета массива int64, я получил следующую ошибку:
"pani c: недопустимый sql тип (фрагмент) для postgres"
моя модель Gorm:
type Game struct {
gorm.Model
GameCode string
GameName string
DeckType []int64
GameEndDate string
}
Обновление на основе ответа @pacuna. Я попробовал предложенный код и получил аналогичную ошибку.
"pani c: недопустимый sql тип Int64Array (slice) для postgres"
Вот полный блок кода :
package main
import (
"fmt"
"github.com/jinzhu/gorm"
_ "github.com/jinzhu/gorm/dialects/postgres"
pq "github.com/lib/pq"
)
var db *gorm.DB
// Test -- Model for Game table
type Test struct {
gorm.Model
GameCode string
GameName string
DeckType pq.Int64Array
GameEndDate string
}
func main() {
db, err := gorm.Open("postgres", "host=localhost port=5432 user=fullstack dbname=scratch_game sslmode=disable")
if err != nil {
fmt.Println(err.Error())
panic("Failed to connect to database...")
}
defer db.Close()
dt := []int64{1, 2, 3}
db.AutoMigrate(&Test{})
fmt.Println("Table Created")
db.Create(&Test{GameCode: "xxx", GameName: "xxx", DeckType: pq.Int64Array(dt), GameEndDate: "xxx"})
fmt.Println("Record Added")
}