Flask-SQLAlchemy加入

时间:2014-09-23 17:03:18

标签: python join sqlalchemy flask-sqlalchemy

你好我在flask-sqlalchemy加入了一个问题。我是数据库和烧瓶的初学者。

这些是我的课程:

class Shopping(db.Model):
    __tablename__ = 'shoppings'
    id = db.Column(db.Integer, primary_key=True)
    product_name = db.Column(db.String(30), index=True, unique=False)
    price=db.Column(db.Float(10), index=True)
    date=db.Column(db.Date())
    s_type_id = db.Column(db.Integer, db.ForeignKey('shopping_types.id'))
    def __repr__(self):
        return 'Alisveris yeri :{0}  Tutar :{1}  Tarih:      {2}'.format(self.product_name,self.price,self.date)

    def __list__(self):
        return [self.product_name,self.price,self.date]

class Shopping_Type(db.Model):
    __tablename__='shopping_types'
    id=db.Column(db.Integer,primary_key=True)
    type_name=db.Column(db.String(30), index=True, unique=True)
    types = db.relationship('Shopping', backref = 'shopping_types', lazy = 'dynamic')
    def __repr__(self):

        return '{0}'.format(self.type_name)

当我尝试使用python终端并运行时:

select shoppings.product_name ,shoppings.price, shoppings.date, shopping_types.type_name from shoppings join shopping_types ON shoppings.s_type_id=shopping_types.id

查询

我得到了我想要的但是当我运行flask-sqlalchemy命令时:

rslt=db.session.query(spng).join(st)
spng:Shopping(class)
st:Shopping_Type(class)

我只获得购物数据。 我想购买Shopping + Shopping_Type数据。

谢谢。

3 个答案:

答案 0 :(得分:5)

rslt = db.session.query(spng, st).join(st)

结果将是tuples (Shopping, Shopping_Type)

的{{1}}

答案 1 :(得分:0)

rslt = db.session.query(spng, st).filter(spng.s_type_id == st.id).all()

for x, y in rslt:
    print("Product ID: {} Product Name: {} Sopping Type: {}".format(x.id, x.product_name, y.tye_name))

type(rslt)是一个元组,包含作为连接表数目的元素。

答案 2 :(得分:-1)

rslt = db.session.query(spng).join(
    st, spng.s_type_id = st.id
).with_entities(
    spng.product_name.label('spng_product_name'),
    spng.price.label('spng_price_label'),
    spng.date.label('spng_date'),
    st.type_name.label('st_type_name'),
)

您可以使用with_entities

使用任何标签