sqlalchemy在删除之前更新另一个模型

Cho*_*onu 5 python sqlalchemy

我在PostgreSQL中使用sqlalchemy。我是sqlalchemy的新手。

我为名为“ to_user_id”的模型“ User”创建了外部密钥,以对“ Invitation”进行建模,该密钥不可为空。

当我尝试使用删除模型“用户”的实例时

session.delete(user)
Run Code Online (Sandbox Code Playgroud)

sqlalchemy会在删除之前自动将邀请的to_user_id设置为NULL,而PostgreSQL则会引发以下错误。

IntegrityError: (IntegrityError) null value in column "to_user_id" violates not-null constraint
Run Code Online (Sandbox Code Playgroud)

如何禁用它?

这是我模型的定义

class User(Base):
    '''
    User model
    '''
    __tablename__='User'
    id = Column(Integer,primary_key=True)

class Invitation(Base):
    '''
    Invitation model
    '''
    __tablename__ = 'Invitation'
    __table_args__ = (UniqueConstraint('appointment_id', 'to_user_id'),)
    id = Column(Integer, primary_key=True)

    appointment_id = Column(Integer,ForeignKey('Appointment.id',
        ondelete='CASCADE'), nullable=False)
    appointment = relationship('Appointment', backref=backref('invitations'),
    )

    from_user_id = Column(Integer,ForeignKey('User.id',
        ondelete='SET NULL'), nullable=True)
    from_user = relationship('User', backref=backref('sent_invitations'),
        primaryjoin='Invitation.from_user_id==User.id')

    to_user_id = Column(Integer,ForeignKey('User.id',
        ondelete='CASCADE'), nullable=False)
    to_user = relationship('User',backref=backref('received_invitations'),
        primaryjoin='Invitation.to_user_id==User.id',
    )
Run Code Online (Sandbox Code Playgroud)

jd.*_*jd. 3

你应该传递cascade='delete'to_user relationship(). 请参阅此处的文档

ondelete参数ForeignKey影响 DDL 语句的生成,而不是 ORM 的行为方式。