首页 > 解决方案 > 使用 GORM 和 echo-framework 进行更新的惯用方式

问题描述

嗨,golang 中的新人,正在尝试制作 rest API

我想使用 GORM 和 golang echo 框架更新仅传递所需数据的实体。我得到这个错误: "strconv.ParseUint: parsing \"ea78944c-a2a9-4813-86e7-10b199d0f002\": invalid syntax"

我使用 echo.Bind() 函数将 formdata(我使用邮递员)与我的 Club 结构绑定。

PS:我使用 xid 到外部 id 并保留我的 int id 来进行工作。

预期的 :

我将通过 GORM 的 id(使用 url 参数获取)在我的数据库中找到 Club,并将其设置在一个新的俱乐部结构中。

之后,我将我的俱乐部结构与我的表单数据绑定。

最后用 Save() GORM 函数保存它。=> 得到错误

现实 :

我将使用 GORM 通过 id(写入硬编码字符串 id)在我的数据库中找到 Club,并将其设置在新的 club 结构中。

之后,我将我的俱乐部结构与我的表单数据绑定。

最后用 Save() GORM 函数保存它。=> 作品

结论 :

我不知道如何使用 echo.Bind() 在 PUT 方法中传递 url 参数和 formdata

这是我的俱乐部结构:

// 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

当我ea78944c-a2a9-4813-86e7-10b199d0f002在更新函数中硬编码我的 xid 时,它就像一个魅力,但我不能将我的 url 和我的 formdata 与 echo.Bind() 结合起来

如果我尝试,我的错误http://localhost:1323/api/updateClub/ea78944c-a2a9-4813-86e7-10b199d0f002

"strconv.ParseUint: parsing \"ea78944c-a2a9-4813-86e7-10b199d0f002\": invalid syntax"

感谢阅读希望有人可以帮助我:)

标签: gogo-gorm

解决方案


您可以尝试c.Param("xid")代替c.Param("id")并将路由参数更改为API.PUT("/updateClub/:xid", handlers.UpdateClub)


推荐阅读