douti0467 2018-12-05 05:50
浏览 49
已采纳

如何从函数返回ref var

I just begin to learn Go, and have a problem with returning ref vars from function

I have a function to get rows from a DB table:

func getData(query string, db *sql.DB) *sql.Rows {
    rows, err := db.Query(query)
    if err != nil {
        fmt.Println("SQL select error: ")
        log.Fatal(err)
    }
    defer rows.Close()

    return rows
}

now I try to get data from db

rows := getData("select * from all_obrash", db)
fmt.Println(rows)

I expect it just returns *sql.Rows but I get nothing

&{0xc00025e100 0x4cf270 0xc0002743c0 <nil> 0xc000248180 {{0 0} 0 0 0 0} true <nil> []}

When I call from main() it works just fine, but when I move code to func it stop get rows, I think I miss something here.

  • 写回答

1条回答 默认 最新

  • dongzhe6287 2018-12-05 07:04
    关注

    defer rows.Close() gets executed when function returns

      func getData(query string, db *sql.DB) *sql.Rows {
        rows, err := db.Query(query)
        if err != nil {
            fmt.Println("SQL select error: ")
            log.Fatal(err)
        }
        defer rows.Close()
    
        return rows
    }
    

    That's why you're not able to read data

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 求帮我调试一下freefem代码
  • ¥15 matlab代码解决,怎么运行
  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?