你好我在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数据。
谢谢。
答案 0 :(得分:5)
rslt = db.session.query(spng, st).join(st)
结果将是tuples
(Shopping, Shopping_Type)
答案 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
使用任何标签