如何使用sqlx检查行是否存在?

时间:2019-02-09 03:49:18

标签: mysql go sqlx

使用sqlx,我想了解查询MySql数据库,以了解对MySql的查询是否返回空行:

所以在this之后,我想到了

var result model.Post
err := database.SQL.Get(&result, "SELECT * FROM post WHERE post_id=? AND user_id=? LIMIT 1", postID, userID)
if err == sql.ErrNoRows { 
    log.Println(err)
    log.Println("post not found")
} else { 
    log.Println("post found")
}

尽管没有行,但我总是得到post found

这可能是什么问题,我该如何解决?

1 个答案:

答案 0 :(得分:2)

如果找到的行err将为nil

这是工作示例:

var result model.Post
err := database.SQL.Get(&result, "SELECT * FROM post WHERE post_id=? AND user_id=? LIMIT 1", postID, userID)

switch err {
case nil:
    log.Printf("user found: %+v\n", user)
case sql.ErrNoRows:
    log.Println("user NOT found, no error")
default:
    log.Printf("error: %s\n", err)
}