创建新结构并将其附加到一对多关系中的数组
Create new struct and append it to array in a one to many relationship
我正在尝试将一个新项目附加到一对多关系中的数组。问题是其中一个 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
}
这是我向其发送 post 请求的路由:
/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
数组,即由路由参数指定?
问题解决了。结果是数据库 table 出现了一些问题。虽然我启用了自动迁移功能,但某些 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)
}
}
我正在尝试将一个新项目附加到一对多关系中的数组。问题是其中一个 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
}
这是我向其发送 post 请求的路由:
/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
数组,即由路由参数指定?
问题解决了。结果是数据库 table 出现了一些问题。虽然我启用了自动迁移功能,但某些 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)
}
}