使用 GORM 和 echo-framework 进行更新的惯用方式
Idiomatic way to update with GORM and echo-framework
你好 golang 的新手,正在努力休息 API
我想使用 GORM 和 golang echo 框架更新仅传递所需数据的实体。
我得到这个错误:
"strconv.ParseUint: parsing \"ea78944c-a2a9-4813-86e7-10b199d0f002\": invalid syntax"
我使用 echo.Bind() 函数将表单数据(我使用邮递员)与我的俱乐部结构绑定。
PS : 我将 xid 用于外部 ID,并保留我的 int id 以进行内部工作。
预计:
我将使用 GORM 通过 ID(通过 url 参数获取)在我的数据库中找到俱乐部,并将其设置在新的俱乐部结构中。
之后,我将我的俱乐部结构与我的表单数据绑定。
最后用 Save() GORM 函数保存它。 => 得到错误
现实:
我将使用 GORM 通过 ID(写入硬编码字符串 ID)在我的数据库中找到俱乐部,并将其设置在新的俱乐部结构中。
之后,我将我的俱乐部结构与我的表单数据绑定。
最后用 Save() GORM 函数保存它。 => 有效
结论:
我不知道如何使用 echo.Bind()
在 PUT 方法中传递 url 参数和表单数据
这是我的俱乐部结构:
// Club struct
type Club struct {
Base
Name string `json:"name;" gorm:"type:varchar(255);not null" validate:"required"`
Slug string `json:"slug;" gorm:"type:varchar(255);unique;not null"`
Website string `json:"website;" gorm:"type:varchar(255)"`
Lat float32 `json:"lat;" gorm:"lat;" sql:"type:decimal(8,6);" validate:"required,numeric"`
Lng float32 `json:"lng;" gorm:"lng;" sql:"type:decimal(9,6);" validate:"required,numeric"`
Logo string `json:"logo;" gorm:"type:varchar(100)" validate:"required"`
Phone string `json:"phone;" gorm:"type:varchar(20)" validate:"required"`
}
我的 FindById 函数:
// GetClubByXID get club by xid
func GetClubByXID(c echo.Context, xid string) (*schemas.Club, error) {
club := new(schemas.Club)
if result := db.Where("xid = ?", xid).First(&club); result.Error != nil {
return nil, result.Error
}
return club, nil
}
这是我的更新功能:
func UpdateClub(c echo.Context) error {
xid := c.Param("id") // => doesn't work
// xid := "ea78944c-a2a9-4813-86e7-10b199d0f002" // => work
club, err := models.GetClubByXID(c, xid)
if err != nil {
return c.JSON(http.StatusNotFound, err)
}
if err := c.Bind(club); err != nil {
return c.JSON(http.StatusInternalServerError, err)
}
db.Save(&club)
return c.JSON(http.StatusOK, echo.Map{
"club": &club,
})
}
我的更新路线:
API.PUT("/updateClub/:id", handlers.UpdateClub) // => doesn't work
// API.PUT("/updateClub", handlers.UpdateClub) // => work
当我在我的更新函数中硬编码我的 xid ea78944c-a2a9-4813-86e7-10b199d0f002
时,它的工作就像一个魅力,但我无法将我的 url 和我的表单数据与 echo.Bind()
我试错了 http://localhost:1323/api/updateClub/ea78944c-a2a9-4813-86e7-10b199d0f002
:
"strconv.ParseUint: parsing \"ea78944c-a2a9-4813-86e7-10b199d0f002\": invalid syntax"
感谢阅读希望有人能帮助我:)
您可以尝试 c.Param("xid")
而不是 c.Param("id")
并将路由参数更改为 API.PUT("/updateClub/:xid", handlers.UpdateClub)
你好 golang 的新手,正在努力休息 API
我想使用 GORM 和 golang echo 框架更新仅传递所需数据的实体。
我得到这个错误:
"strconv.ParseUint: parsing \"ea78944c-a2a9-4813-86e7-10b199d0f002\": invalid syntax"
我使用 echo.Bind() 函数将表单数据(我使用邮递员)与我的俱乐部结构绑定。
PS : 我将 xid 用于外部 ID,并保留我的 int id 以进行内部工作。
预计:
我将使用 GORM 通过 ID(通过 url 参数获取)在我的数据库中找到俱乐部,并将其设置在新的俱乐部结构中。
之后,我将我的俱乐部结构与我的表单数据绑定。
最后用 Save() GORM 函数保存它。 => 得到错误
现实:
我将使用 GORM 通过 ID(写入硬编码字符串 ID)在我的数据库中找到俱乐部,并将其设置在新的俱乐部结构中。
之后,我将我的俱乐部结构与我的表单数据绑定。
最后用 Save() GORM 函数保存它。 => 有效
结论:
我不知道如何使用 echo.Bind()
在 PUT 方法中传递 url 参数和表单数据这是我的俱乐部结构:
// Club struct
type Club struct {
Base
Name string `json:"name;" gorm:"type:varchar(255);not null" validate:"required"`
Slug string `json:"slug;" gorm:"type:varchar(255);unique;not null"`
Website string `json:"website;" gorm:"type:varchar(255)"`
Lat float32 `json:"lat;" gorm:"lat;" sql:"type:decimal(8,6);" validate:"required,numeric"`
Lng float32 `json:"lng;" gorm:"lng;" sql:"type:decimal(9,6);" validate:"required,numeric"`
Logo string `json:"logo;" gorm:"type:varchar(100)" validate:"required"`
Phone string `json:"phone;" gorm:"type:varchar(20)" validate:"required"`
}
我的 FindById 函数:
// GetClubByXID get club by xid
func GetClubByXID(c echo.Context, xid string) (*schemas.Club, error) {
club := new(schemas.Club)
if result := db.Where("xid = ?", xid).First(&club); result.Error != nil {
return nil, result.Error
}
return club, nil
}
这是我的更新功能:
func UpdateClub(c echo.Context) error {
xid := c.Param("id") // => doesn't work
// xid := "ea78944c-a2a9-4813-86e7-10b199d0f002" // => work
club, err := models.GetClubByXID(c, xid)
if err != nil {
return c.JSON(http.StatusNotFound, err)
}
if err := c.Bind(club); err != nil {
return c.JSON(http.StatusInternalServerError, err)
}
db.Save(&club)
return c.JSON(http.StatusOK, echo.Map{
"club": &club,
})
}
我的更新路线:
API.PUT("/updateClub/:id", handlers.UpdateClub) // => doesn't work
// API.PUT("/updateClub", handlers.UpdateClub) // => work
当我在我的更新函数中硬编码我的 xid ea78944c-a2a9-4813-86e7-10b199d0f002
时,它的工作就像一个魅力,但我无法将我的 url 和我的表单数据与 echo.Bind()
我试错了 http://localhost:1323/api/updateClub/ea78944c-a2a9-4813-86e7-10b199d0f002
:
"strconv.ParseUint: parsing \"ea78944c-a2a9-4813-86e7-10b199d0f002\": invalid syntax"
感谢阅读希望有人能帮助我:)
您可以尝试 c.Param("xid")
而不是 c.Param("id")
并将路由参数更改为 API.PUT("/updateClub/:xid", handlers.UpdateClub)