我对使用SQLAlchemy的两个模块感到有些困惑。这是我的代码:
Base = declarative_base()
class Restaurant(Base):
__tablename__ = 'restaurant'
id = Column(Integer, primary_key=True)
name = Column(String(250), nullable=False)
class MenuItem(Base):
__tablename__ = 'menu_item'
name =Column(String(80), nullable = False)
id = Column(Integer, primary_key = True)
description = Column(String(250))
price = Column(String(8))
course = Column(String(250))
restaurant_id = Column(Integer,ForeignKey('restaurant.id'))
restaurant = relationship(Restaurant)
据我所知,ForeignKey用于定义menu_item表的restaurant_id列和餐厅表的id列之间的外键关系。但为什么餐厅=关系(餐厅)使用?
答案 0 :(得分:3)
restaurant_id
将引用id(列值)。 restaurant
将引用一个Restaurant
实例,该实例将在访问时从数据库中延迟加载(如果您之前设置了正确的内容,则会急切加载)。如果您在backref
上设置relationship
,则还可以访问MenuItem
中的Restaurant
个对象列表。