use*_*585 5 python sqlalchemy flask flask-sqlalchemy
我正在尝试做一个像这样的简单连接查询,
SELECT food._id, food.food_name, food_categories.food_categories FROM food JOIN food_categories ON food.food_category_id = food_categories._id
Run Code Online (Sandbox Code Playgroud)
但不断收到错误。这是我的课程设置方式。
class Food_Categories(db.Model):
__tablename__ = 'food_categories'
_id = db.Column(db.Integer, primary_key=True)
food_categories = db.Column(db.String(30))
class Food(db.Model):
__tablename__ = 'food'
_id = db.Column(db.Integer, primary_key=True)
food_name = db.Column(db.String(40))
food_category_id = db.Column(db.Integer, ForeignKey(Food_Categories._id))
food_category = relationship("Food_Categories")
Run Code Online (Sandbox Code Playgroud)
我的查询函数看起来像这样。
@app.route('/foodlist')
def foodlist():
if request.method == 'GET':
results = Food.query.join(Food_Categories.food_categories).all()
json_results = []
for result in results:
d = {'_id': result._id,
'food': result.food_name,
'food_category': result.food_categories}
json_results.append(d)
return jsonify(user=json_results)
Run Code Online (Sandbox Code Playgroud)
我正在使用烧瓶。当我调用路线时,我收到此错误。
AttributeError: 'ColumnProperty' object has no attribute 'mapper'
Run Code Online (Sandbox Code Playgroud)
我基本上想要这个:
| id | food_name | food_category |
Run Code Online (Sandbox Code Playgroud)
并将 food_category_id 列替换为位于其他表中的食品类别的实际名称。
我的表/关系设置正确吗?我的查询设置是否正确?
您的表和关系设置正确。您的查询需要更改。
错误的原因是您尝试对列 ( Food_Categories.food_categories) 而不是表(或映射的模型对象)执行连接。从技术上讲,您应该用以下查询替换您的查询以修复错误:
results = Food.query.join(Food_Categories).all()
Run Code Online (Sandbox Code Playgroud)
这将修复错误,但不会生成SQL您想要的语句,因为Food即使存在连接,它也只会返回实例作为结果。
为了构建一个查询,该查询将准确生成SQL您想到的语句:
results = (db.session.query(Food._id, Food.food_name,
Food_Categories.food_categories,)
.join(Food_Categories)).all()
for x in results:
# print(x)
print(x._id, x.food_name, x.food_categories)
Run Code Online (Sandbox Code Playgroud)
请注意,在这种情况下,结果不是 的实例Food,而是tuples具有 3 个列值。
| 归档时间: |
|
| 查看次数: |
9068 次 |
| 最近记录: |