使用 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)