簡體   English   中英

Flask-SQLAlchemy 連接

[英]Flask-SQLAlchemy join

您好,我在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 數據。

謝謝你。

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

結果將是一個可枚舉的(Shopping, Shopping_Type) tuples

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) 是一個元組,包含作為連接表數量的元素。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM