使用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
。
这可能是什么问题,我该如何解决?
答案 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)
}