栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

sqlalchemy:创建关系,但在数据库中没有外键约束?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

sqlalchemy:创建关系,但在数据库中没有外键约束?

无需定义“模式”级别

ForeignKey
约束,而是创建自定义的外部条件;将您要用作“外键”的列以及
primaryjoin
传递给
relationship
。您必须手动定义
primaryjoin
原因,因为:

默认情况下,此值是基于父表和子表(或关联表)的外键关系计算的。

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
using中内联注释
foreign()

a = relationship('A', primaryjoin='foreign(C.a_id) == A.a_id')

您可以验证没有

FOREIGN KEY
为表 c 发出约束:

In [4]: from sqlalchemy.schema import CreateTableIn [5]: print(CreateTable(A.__table__))CREATE TABLE a (        a_id INTEGER NOT NULL,         PRIMARY KEY (a_id))In [6]: print(CreateTable(C.__table__))CREATE TABLE c (        c_id INTEGER NOT NULL,         a_id INTEGER,         PRIMARY KEY (c_id))

警告:

请注意,

FOREIGN KEY
在数据库端没有适当的约束,您可以以任何所需的方式将参照完整性破坏成碎片。在ORM
/应用程序级别存在关系,但是不能在数据库中强制执行。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/651931.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号