使用 golang、gin 和 gorm 以及 postgres 进行验证,例如数据库中已存在电子邮件

pol*_*ium 5 postgresql go go-gorm

在此输入图像描述我有这样的东西,我想检查电子邮件是否已存在于数据库中:

func RegisterUser(c *gin) {
var user models.User
if err := c.ShouldBindJSON(&user); err != nil {
    c.JSON(http.StatusBadRequest, gin.H{
        "messAge": err.Error(),
        "data":    "",
    })
    return
}
// **I TRIED SOEMTHING LIKE THIS**
err := database.DB.Find(&user.Email).Error
if err != nil {
    c.JSON(401, gin.H{"MESSAGE": "Email ALREADY exist",
    return
}
// **but is not working, because ANY mail it give me error**


if !strings.Contains(user.Email, "@") {
    c.JSON(400, gin.H{"MESSAGE": utils.ErrEmailWrong})
    return
}

if len(user.Password) < 4 {
    c.JSON(400, gin.H{"MESSAGE": utils.ErrPasswordLength})
    return
}

database.DB.Create(&user)
c.JSON(200, gin.H{
    "MESSAGE": "CREATED",
})
}
Run Code Online (Sandbox Code Playgroud)

使用这段代码,每次都告诉我:电子邮件已经存在,仅在第一次时有效。

小智 2

请阅读文档: https: //gorm.io/docs/query.html

var userFind models.User
database.DB.Where("email = ?", user.Email).First(&userFind)

Run Code Online (Sandbox Code Playgroud)