Добавление массива целых чисел в качестве типа данных в модели Горма - PullRequest
3 голосов
/ 05 августа 2020

Я пытаюсь сохранить массив чисел в одном поле 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")
}

1 Ответ

2 голосов
/ 05 августа 2020

Вам необходимо использовать настраиваемые типы из базовой библиотеки:

type Game struct {                                           
        gorm.Model                                           
        GameCode    string                                      
        GameName    string                                      
        DeckType    pq.Int64Array `gorm:"type:integer[]"`
        GameEndDate string    
}   

// example insertion
dt := []int64{1, 2, 3}   
                                                                                
db.Create(&Game{GameCode: "xxx", GameName: "xxx", DeckType: pq.Int64Array(dt), GameEndDate: "xxx"})    
...