初级会员
  • 第 15695 位会员
  • zoupeng77
  • 2018-01-23 17:43:26
  • Offline
  • 19 88

最近发布的文章

    暂无

最近分享的资源

    暂无

最近发布的项目

    暂无

最近的评论

  • #2 @lishihai mysql数据库包:github.com/go-sql-driver/mysql,只不过我把*sql.DB对象放在项目的models包里。 我具体分析下: 例1和例3中,blogRows都是用defer延迟关闭的,所以在catRows创建查询的时候,blogRows是没有关闭的,catRows创建后,无论catRows是否关闭,blogRows都会被一直挂起,无法关闭,我设计出第5例: ```go func abc() interface{} { blogRows, _ := models.Db.Query("select * from blog where id=1") catRows, _ := models.Db.Query("select * from category where id=1") catRows.Close() blogRows.Close() return 1 } ``` 这样,blogRows依然关闭不了。 我也就发现了这个问题,但究竟是怎么造成的,还不知道。现在的解决方式是,查询一次导出数据后立即关闭,不能在查询中套查询,不能在查询中用递归函数。
  • 好了,自己解决了。我发现第一个查询在没有关闭的情况下,创建新的查询,不管后面怎么关闭,都关闭不了第一个查询。