这个问题是“Filter relationships and paginate in Flask-SQLAlchemy”的简化,这里的答案也可能会产生解决方案。
假设我有一个简单的模型类设计:
from flask import Flask
from flask.ext.sqlalchemy import SQLAlchemy
app = Flask(__name__)
db = SQLAlchemy(app)
class Design(db.Model):
__tablename__ = 'design'
id = db.Column(db.Integer, primary_key=True)
designname = db.Column(db.String(64))
我可以像这样得到一个Flask-SQLAlchemy BaseQuery对象:
>>> Design.query
<flask_sqlalchemy.BaseQuery object at 0x7f0b29c63990>
我可以按照您的预期恢复数据:
>>> Design.query.all()
[<item1>, <item2>, <item3>]
我也可以通过这种方式获取BaseQuery对象(我认为这对于更复杂的查询是必要的,例如,带有连接的查询):
>>> db.Query(Design)
<flask_sqlalchemy.BaseQuery object at 0x7f0b29c6fdd0>
它看起来应该是相同的对象类型 - 实际上,生成的SQL是相同的:
>>> str(db.Query(Design)) == str(Design.query)
True
然而,当我在这里尝试all()方法时,它不起作用:
>>> db.Query(Design).all()
Traceback (most recent call last):
File "<debugger>", line 1, in <module>
db.Query(Design).all()
File "/usr/local/lib/python2.7/dist-packages/sqlalchemy/orm/query.py", line 2320, in all
return list(self)
File "/usr/local/lib/python2.7/dist-packages/sqlalchemy/orm/query.py", line 2437, in __iter__
self.session._autoflush()
AttributeError: 'NoneType' object has no attribute '_autoflush'
编辑:我认为问题在于第二种方法是没有将会话附加到BaseQuery对象。第一种方法有一个:
>>> Design.query.session
<flask_sqlalchemy.SignallingSession object at 0x7f0b29fbd510>
但另一种方法不是:
>>> db.Query(Design).session is None
True
非常感谢任何见解。
答案 0 :(得分:4)
你应该可以使用
db.session.query(Design).all()
session.query
是在没有Flask-SQLAlchemy的情况下使用SQLAlchemy时执行查询的方式。
更新
使用Flask-SQLAlchemy的BaseQuery
:
Design.query.join(YourOtherModel).all()