我在Userownedshare表和Share表之间有多对一的关系.
当我从数据库中删除Userownedshare条目时,我收到以下错误:AssertionError:依赖关系规则试图清空主键列’share.ticker’
这是有道理的,因为Userownedshare中的股票代码字段是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关系.
我需要将cascade =“all,delete-orphan”添加到Share类中的tickermatch关系.
但我还需要在Userownedshare类的名称关系中添加lazy =“joined”
class Userownedshare(db.Model):
id = db.Column(db.Integer,foreign_keys=[ticker],lazy="joined")
class Share(db.Model):
id = db.Column(db.Integer)
name = db.Column(db.String(50),cascade="all,delete-orphan",lazy="joined")