SqlAlchemy不使用外键创建Relationship

In [2]: class A(Base):
   ...:     a_id = Column(Integer, primary_key=True)
   ...:     __tablename__ = 'a'
   ...:     

In [3]: class C(Base):
   ...:     c_id = Column(Integer, primary_key=True)
   ...:     a_id = Column(Integer)
   ...:     __tablename__ = 'c'
   ...:     a = relationship('A', foreign_keys=[a_id],
   ...:                      primaryjoin='A.a_id == C.a_id')
   ...:

或者直接在primaryjoin参数中使用foreign()进行定义:

a = relationship('A', primaryjoin='foreign(C.a_id) == A.a_id')
SQLAlchemy中定义外键可以使用ForeignKey约束。下面是一个示例代码: ```python from sqlalchemy import create_engine, Column, Integer, String, ForeignKey from sqlalchemy.ext.declarative import declarative_base from sqlalchemy.orm import relationship engine = create_engine('sqlite:///example.db', echo=True) Base = declarative_base() class User(Base): __tablename__ = 'users' id = Column(Integer, primary_key=True) name = Column(String) addresses = relationship("Address", back_populates="user") class Address(Base): __tablename__ = 'addresses' id = Column(Integer, primary_key=True) email_address = Column(String, nullable=False) user_id = Column(Integer, ForeignKey('users.id')) user = relationship("User", back_populates="addresses") Base.metadata.create_all(engine) ``` 在这个示例中,我们定义了两个表:User和Address。Address表中有一个外键user_id,它引用了User表中的id列。这个外键使用ForeignKey约束来定义。 在User表的定义中,我们使用relationship属性来定义与Address表的关系。这个属性告诉SQLAlchemy,User表的每个实例都有一个addresses属性,它是一个包含所有与该用户相关的Address实例的列表。 当我们使用这些模型类时,例如: ```python from sqlalchemy.orm import sessionmaker Session = sessionmaker(bind=engine) session = Session() user = User(name='John Doe') address = Address(email_address='john.doe@example.com', user=user) session.add(user) session.add(address) session.commit() user = session.query(User).filter_by(name='John Doe').one() print(user.addresses) ``` 我们可以看到,我们可以通过user.addresses属性访问与该用户相关的所有地址。这是通过relationship属性定义的。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

DexterLien

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值