您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

python – 尝试删除记录时,依赖关系规则尝试在SQL-Alchemy中清空主键列

5b51 2022/1/14 8:22:02 python 字数 2957 阅读 501 来源 www.jb51.cc/python

我在Userownedshare表和Share表之间有多对一的关系.当我从数据库中删除Userownedshare条目时,我收到以下错误:AssertionError:依赖关系规则试图清空主键列'share.ticker'这是有道理的,因为Userownedshare中的股票代码字段是Share表中的外键.但是,我无法解决如何解决此错误.我认为我想在Shar

概述

我在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])

但我还需要在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")

总结

以上是编程之家为你收集整理的python – 尝试删除记录时,依赖关系规则尝试在SQL-Alchemy中清空主键列全部内容,希望文章能够帮你解决python – 尝试删除记录时,依赖关系规则尝试在SQL-Alchemy中清空主键列所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶