登录
首页 >  Golang >  Go问答

db.Query是否会返回空结果?

来源:stackoverflow

时间:2024-03-06 21:48:24 429浏览 收藏

欢迎各位小伙伴来到golang学习网,相聚于此都是缘哈哈哈!今天我给大家带来《db.Query是否会返回空结果?》,这篇文章主要讲到等等知识,如果你对Golang相关的知识非常感兴趣或者正在自学,都可以关注我,我会持续更新相关文章!当然,有什么建议也欢迎在评论留言提出!一起学习!

问题内容

当 sql 查询预计不会返回任何结果时,我似乎无法从 db.query 中获取 errnorows。

results, err := database.Query("SELECT title FROM accountProject WHERE accountID=? AND MATCH(title) AGAINST(?)", accountID, query)
if err != nil {
    if err == sql.ErrNoRows {
        return errProjectDoesNotExist
    }
    return err
}

解决方案


DB.QueryDB.QueryContext 不会返回值 sql.ErrNoRows。当结果集没有行时,第一次调用 Rows.Next 将返回 false。

在从 DB.QueryRowDB.QueryRowContext 返回的占位符行上调用 Row.Scan 返回值 sql.ErrNoRows。db.queryrow* 方法在出错时返回占位符行,而不是直接返回错误。

如果应用程序正在查找零行或一行,请使用 queryrow 而不是 query。

row := database.QueryRow("SELECT title FROM accountProject WHERE accountID=? AND MATCH(title) AGAINST(?)", accountID, query)
err := row.Scan( .... address of variables here ... )
if err == sql.ErrNoRows {
    return errProjectDoesNotExist
} else if err != nil {
    return err
}

今天带大家了解了的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>