【发布时间】:2016-01-26 21:50:16
【问题描述】:
我正在将 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
它给了我以下错误“AttributeError:'Cursor'对象没有属性'cursor'”
经过一番调查,当我自己执行 mysql.connect() 时,它返回了一个连接对象,但是当我在 with 语句中执行此操作时……它返回了一个游标对象!所以这行得通:
with mysql.connect() as cursor:
#do database stuff
那么这里发生了什么?为什么在 with 语句中返回类型会改变?我查看了Flask-MySQL的源代码,但找不到任何东西......
另外,在 with 块的末尾关闭数据库连接是否仍然可以正常工作?
相关版本信息:
- Python == 2.7.3
- 烧瓶 == 0.10.1
- Flask-MySQL == 1.3
【问题讨论】: