```go
func abc() interface{} {
blogRows, _ := models.Db.Query("select * from blog where id=1")
defer blogRows.Close()
catRows, _ := models.Db.Query("select * from category where id=1")
defer catRows.Close()
return 1
}
```
这样并没有实现我想要的释放掉两个资源,似乎只释放了一个。于是我又做了以下实验:
```go
func abc() interface{} {
blogRows, _ := models.Db.Query("select * from blog where id=1")
blogRows.Close()
catRows, _ := models.Db.Query("select * from category where id=1")
defer catRows.Close()
return 1
}
```
这样就都能释放
```go
func abc() interface{} {
blogRows, _ := models.Db.Query("select * from blog where id=1")
defer blogRows.Close()
catRows, _ := models.Db.Query("select * from category where id=1")
catRows.Close()
return 1
}
```
这样同样只释放了一个
```go
func abc() interface{} {
blogRows, _ := models.Db.Query("select * from blog where id=1")
blogRows.Close()
catRows, _ := models.Db.Query("select * from category where id=1")
catRows.Close()
return 1
}
```
这样当然肯定是没有问题的,都能释放
请教各位大神,这个defer在这里面究竟是个什么原理。
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依然关闭不了。
我也就发现了这个问题,但究竟是怎么造成的,还不知道。现在的解决方式是,查询一次导出数据后立即关闭,不能在查询中套查询,不能在查询中用递归函数。
#4
更多评论
具体如何解决的,能分享下么?
为什么"第一个查询在没有关闭的情况下,创建新的查询,不管后面怎么关闭,都关闭不了第一个查询"?
你用的什么包来做数据库操作的?
#2