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



如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!欢迎各位转载,但是未经作者本人同意,转载文章之后必须在文章页面明显位置给出作者和原文连接,否则保留追究法律责任的权利。
posted @   Dus  阅读(992)  评论(0编辑  收藏  举报
编辑推荐:
· Java 中堆内存和栈内存上的数据分布和特点
· 开发中对象命名的一点思考
· .NET Core内存结构体系(Windows环境)底层原理浅谈
· C# 深度学习:对抗生成网络(GAN)训练头像生成模型
· .NET 适配 HarmonyOS 进展
阅读排行:
· 手把手教你更优雅的享受 DeepSeek
· 腾讯元宝接入 DeepSeek R1 模型,支持深度思考 + 联网搜索,好用不卡机!
· AI工具推荐:领先的开源 AI 代码助手——Continue
· 探秘Transformer系列之(2)---总体架构
· V-Control:一个基于 .NET MAUI 的开箱即用的UI组件库
点击右上角即可分享
微信分享提示