如何在Flask-SQLAlchemy中进行多对多查询?

时间:2014-04-06 02:32:25

标签: python mysql sqlalchemy flask flask-sqlalchemy

我正在使用Flask和SQL-Alchemy为我的Android Applicaiton创建API。我有一个MySQL数据库,表格设置如下:

symptoms:
|    _id     |    symptom     |

food_categories:
|    _id     |    food_categories   |

food_recommendation_type:
|    _id     |    food_categories   |

symptom_food_relationship: (This table is association table relating all three)
|     id     |       symptom_id     |   food_category_id  | food_recommendation_type_id  |

在我的Flask应用程序中,我已经绘制出每个表:

symptom_food_relationship_table = db.Table('symptom_food_relationship',
                       db.Column('id', db.Integer),
                       db.Column('symptom_id', db.Integer, ForeignKey('symptoms._id')),
                       db.Column('food_category_id', db.Integer, ForeignKey('food_categories._id')),
                       db.Column('food_recommendation_type_id', db.Integer, ForeignKey('food_recommendation_type._id')))

class Symptom(db.Model):
__tablename__ = 'symptoms'
_id = db.Column(db.Integer, primary_key=True)
symptom = db.Column(db.String(100))
symptom_food_relationship = relationship("Food_Categories",
                                         secondary=symptom_food_relationship_table)

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_Recommendation_Type(db.Model):
__tablename__ = 'food_recommendation_type'
_id = db.Column(db.Integer, primary_key=True)
food_recommendation_type = db.Column(db.String)

表格如下:

id symptom_id food_categoryid food_recommendation_id
1   1          2                    1
11  1          8                1
21  1          0                3
31  1          3                3

我的问题是我将用于将这些值更改为其名称的查询。要查询一个表,我会说results = Symptom.query.all()。我知道要完成此任务的SQL语句是......

SELECT s.symptom, fc.food_categories, fr.food_recommendation_type
FROM symptoms AS s 
INNER JOIN symptom_food_relationship AS srt
INNER JOIN food_categories AS fc
INNER JOIN food_recommendation_type AS fr
ON s._id = srt.symptom_id
AND fc._id = srt.food_category_id
AND fr._id = srt.food_recommendation_type_id
WHERE s._id='1'
ORDER BY s.symptom, food_categories

什么是SQL炼金术查询语句等同于此。所以我可以在JSON Response中构建它。

1 个答案:

答案 0 :(得分:0)

你想得到这样的东西:

results = (session.query(Symptom)
              .join(Symptom. symptom_food_relationship)
              .values(Symptom.symptom,
                      Food_Categories. food_categories,
                      Food_Recommendation_Type.food_recommendation_type))

结果以某种方式收集:

resultlist = []
for username, message, time in results:
    resultlist.append({'symptom': symptom,
                       'food_categories': food_categories,
                       'food_recommendation_type': food_recommendation_type})

可能有更优雅的方式来实现您的数据结构,但这个方法应该有效。

如果您阅读此问题的文档,则最好: http://docs.sqlalchemy.org/en/rel_0_9/orm/query.html#sqlalchemy.orm.query.Query.join

祝你好运:)