创建新结构并将其以一对多关系添加到数组

时间:2018-11-03 14:55:12

标签: postgresql go go-gorm go-gin

我正在尝试以一对多关系将新项目追加到数组中。问题在于,其中一个ID始终是未定义的,我要附加的模型也不会更新。

我有以下型号:

type Station struct {
    gorm.Model
    Name         string
    Measurements []Measurement
    PlantID      uint64
    Plant        Plant
}

type Measurement struct {
    ID             uint64 `gorm:"primary_key"`
    StationID      uint64
    TempSensor     float32
    LightSensor    float32
    HumiditySensor float32
    CreatedAt      time.Time
}

type Plant struct {
    gorm.Model
    Name string
}

这是我发送帖子请求的路径:

/stations/:id/measurements

这是我当前拥有的路由处理程序:

func CreateMeasurement(c *gin.Context) {
    id := c.Params.ByName("id")
    var station Station
    if err := db.Where("id = ?", id).First(&station).Error; err != nil {
        c.AbortWithStatus(404)
        fmt.Println(err)
    } else {
        var measurement Measurement
        c.BindJSON(&measurement)

        // Convert params string to uint
        convertedID, err := strconv.ParseUint(id, 10, 64)
        if err != nil {
            fmt.Println(err)
        }
        measurement.StationID = convertedID

        db.Model(&station).Association("Measurements").Append(&measurement)
        db.Save(&station)
        c.JSON(200, station)
    }
}

问题:如何创建新的Measurement项目并将其附加到由路由参数指定的特定[]Measurement中的Station数组中?

1 个答案:

答案 0 :(得分:1)

解决了问题。事实证明,数据库表存在一些问题。尽管我启用了自动迁移功能,但某些ID为空的问题仍然存在。

这是工作路线:

func CreateMeasurement(c *gin.Context) {
    id := c.Params.ByName("id")
    var station Station
    if err := db.Where("id = ?", id).First(&station).Error; err != nil {
        c.AbortWithStatus(404)
        fmt.Println(err)
    } else {
        var measurement Measurement
        c.BindJSON(&measurement)

        db.Model(&station).Association("Measurements").Append(&measurement)
        c.JSON(200, station)
    }
}