gpt4 book ai didi

python - 尝试删除记录时,依赖规则试图清空 SQL-Alchemy 中的主键列

转载 作者:太空狗 更新时间:2023-10-30 00:10:07 26 4
gpt4 key购买 nike

Userownedshare 表和 Share 表之间存在多对一关系。

当我从数据库中删除 Userownedshare 条目时,出现以下错误:AssertionError: Dependency rule tried to blank-out primary key column 'share.ticker'

这是有道理的,因为 Userownedshare 中的 ticker 字段是 Share 表中的外键。但是我不知道如何解决这个错误。我想我想在 Share 条目被孤立时设置级联删除,但我不知道该怎么做,我已经阅读了文档,但我最终遇到了不同类型的错误,所以我想我错过了一些微不足道的东西。希望有人能帮忙,谢谢!


这是我的代码:

class Userownedshare(db.Model):
id = db.Column(db.Integer, primary_key=True)
ticker = db.Column(db.String(20), db.ForeignKey('share.ticker'))
user = db.Column(db.String, db.ForeignKey('user.username'))
quantity = db.Column(db.Integer, nullable=False)
dividends = db.Column(db.Float, server_default="0.0")
triggerlevel = db.Column(db.Integer)
smsalert = db.Column(db.Boolean)
emailalert = db.Column(db.Boolean)
portfolioid = db.Column(db.String(50))
name = db.relationship('Share', backref='userownedshare' , foreign_keys=[ticker])

class Share(db.Model):
id = db.Column(db.Integer)
name = db.Column(db.String(50), nullable=False)
ticker = db.Column(db.String(50), db.ForeignKey('userownedshare.ticker'), primary_key=True)
tickermatch = db.relationship('Userownedshare', backref='share', foreign_keys=[ticker])

最佳答案

好的,经过反复试验,我解决了这个问题。我需要将 cascade="all, delete-orphan", 添加到 Share 类中的 tickermatch 关系。

但我还需要将 lazy="joined" 添加到 Userownedshare 类中的 name 关系

class Userownedshare(db.Model):
id = db.Column(db.Integer, primary_key=True)
ticker = db.Column(db.String(20), db.ForeignKey('share.ticker'))
user = db.Column(db.String, db.ForeignKey('user.username'))
quantity = db.Column(db.Integer, nullable=False)
dividends = db.Column(db.Float, server_default="0.0")
triggerlevel = db.Column(db.Integer)
smsalert = db.Column(db.Boolean)
emailalert = db.Column(db.Boolean)
portfolioid = db.Column(db.String(50))
name = db.relationship('Share', backref='userownedshare', foreign_keys=[ticker], lazy="joined")

class Share(db.Model):
id = db.Column(db.Integer)
name = db.Column(db.String(50), nullable=False)
ticker = db.Column(db.String(50), db.ForeignKey('userownedshare.ticker'), primary_key=True)
tickermatch = db.relationship('Userownedshare', backref='share', cascade="all, delete-orphan", lazy="joined")

关于python - 尝试删除记录时,依赖规则试图清空 SQL-Alchemy 中的主键列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35040724/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com