登录
首页 >  Golang >  Go问答

如何获取使用数据库/sql 时返回的行数?

来源:Golang技术栈

时间:2023-04-14 05:59:56 243浏览 收藏

你在学习Golang相关的知识吗?本文《如何获取使用数据库/sql 时返回的行数?》,主要介绍的内容就涉及到golang,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!

问题内容

给定以下功能:

func (me *OrderService) GetOrders(orderTx *sql.Tx, orderId int) (orders *sql.Rows) {
    orders, err := ecommTx.Query("SELECT * FROM orders WHERE id=?", orderId)
    if err != nil {
        log.Fatal(err)
    }
    log.Printf("Successfully queried and receive %d orders", orders.count)
    return orders
}

有没有简单的方法来计算结果?我想保持这个数据库引擎的竞争性,但是 FWIW.... 我正在使用Matt N 的 sqlite3 驱动程序进行集成测试,但计划在产品中使用不同的数据库。

正确答案

sql.Query()返回*RowsRows是一个读者,而不是一个集合,所以诸如count()or之类的调用len()是不相关的。您必须通读Rows才能知道您有多少条目:

count := 0
for orders.Next() {
    count++
}

log.Printf("Successfully queried and receive %d orders", count)

这样做不会增加任何额外的开销。其他可能返回带有count属性的集合的语言(例如 C# 或 Delphi)只是为您进行读取并将结果打包到一个集合中以方便您使用。

理论要掌握,实操不能落!以上关于《如何获取使用数据库/sql 时返回的行数?》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

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