使用GORM和回声框架进行更新的惯用方式

时间:2019-11-01 15:50:55

标签: go go-gorm

您好,golang的新手,并尝试制作rest API

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

我使用echo.Bind()函数将表单数据(我使用邮递员)与Club结构绑定在一起。

PS:我将xid用作外部ID,并保留int ID以进行内部工作。

预期:

我将使用GORM通过ID(在URL参数中获取)在我的数据库中找到Club,并将其设置为新的Club结构。

之后,我将club结构与formdata绑定。

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

现实:

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

之后,我将club结构与formdata绑定。

最后使用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

当我在更新函数中对xid ea78944c-a2a9-4813-86e7-10b199d0f002进行硬编码时,它的工作就像是一种魅力,但是我无法将URL和formdata与echo.Bind()结合起来

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

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

感谢阅读,希望有人能帮助我:)

1 个答案:

答案 0 :(得分:1)

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