我正在使用Flask和Flask-MySQL,并且之前正在执行以下操作:
db = mysql.connect()
cursor = db.cursor()
#do database stuff
cursor.close()
db.close()
但我想我会让事情变得更干净、更惯用,所以我尝试了:
with mysql.connect() as db, db.cursor() as cursor:
#do database stuff
它给了我以下错误"属性错误:"游标"对象没有属性'游标'"
经过一番调查,当我自己做 mysql.connect() 时,它会返回一个连接对象,但是当我在 with 语句中执行此操作时......它返回一个游标对象! 所以这有效:
with mysql.connect() as cursor:
#do database stuff
这到底是怎么回事呢? 为什么在 with 语句中返回类型会更改? 我浏览了Flask-MySQL的源代码,但找不到任何东西......
另外,这是否仍然可以正常工作以关闭 with 块末尾的数据库连接?
相关版本信息:
- 蟒蛇 == 2.7.3
- 烧瓶 == 0.10.1
- Flask-MySQL == 1.3
表达式:
with X as Y:
....
并不意味着Y
"是"X
. 相反,调用X.__enter__()
,然后其结果绑定到with
语句正文的Y
。
在with
正文的末尾或发生异常时,将调用 X.__exit__(...)
来处理成功或失败。
在这种情况下,作为连接的 mysql.connect()
的结果将公开执行以下操作的上下文管理器:
-
__enter__
创建游标并开始事务; -
__exit__
根据需要提交或回滚事务。