gpt4 book ai didi

postgresql - 创建新结构并将其附加到一对多关系中的数组

转载 作者:IT王子 更新时间:2023-10-29 01:44:02 24 4
gpt4 key购买 nike

我正在尝试以一对多关系将新项目附加到数组。问题是其中一个 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 项并将其附加到特定Station 中的[]Measurement 数组路由参数指定的是哪个?

最佳答案

问题解决了。事实证明数据库表有问题。虽然我启用了自动迁移,但某些 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)
}
}

关于postgresql - 创建新结构并将其附加到一对多关系中的数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53132474/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com