Python自动化之sqlalchemy复合外键

复合外键用法

metadata = MetaData(engine)
                classedu = Table('classedu', metadata,
                # Column('qq', BigInteger, primary_key=True),
                Column('classname', VARCHAR(20), primary_key=True),
                Column('coursename', VARCHAR(20),primary_key=True))


##这是一个复合外键
student = Table('student', metadata,
             Column('qq', BigInteger, primary_key=True),
             Column('classname', VARCHAR(20)),
             Column('coursename', VARCHAR(20)),
             ForeignKeyConstraint(['classname', 'coursename'], ['classedu.classname', 'classedu.coursename'])
             )

metadata.create_all(engine)


Base = declarative_base()


book_m2m_author = Table('book_m2m_author', Base.metadata,
                        Column('book_id',Integer,ForeignKey('books.id')),
                        Column('author_id',Integer,ForeignKey('authors.id')),
                        )

class Book(Base):
    __tablename__ = 'books'
    id = Column(Integer,primary_key=True)
    name = Column(String(64))
    pub_date = Column(DATE)
    authors = relationship('Author',secondary=book_m2m_author,backref='books')

参考如下
http://docs.sqlalchemy.org/en/rel_1_1/core/constraints.html

转载于:https://www.cnblogs.com/wspblog/p/6008704.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值