4 Flask开发进阶:记下一次级联删除的报错:Cannot delete or update a parent row: a foreign key constraint fails

中间表

class Permission(object):
    LOGIN = 0x01
    EDITOR = 0x02
    OPERATOR = 0x04
    ADMINISTER = 0xff
    PERMISSION_MAP = {
        LOGIN: ('login', 'Login user'),
        EDITOR: ('editor', 'Editor'),
        OPERATOR: ('op', 'Operator'),
        ADMINISTER: ('admin', 'Super administrator')
    }


# 中间表
roles_users = db.Table(
    'tbl_roles_users',
    db.Column('user_id', db.Integer, ForeignKey(
        'tbl_user.id', ondelete='CASCADE', onupdate='CASCADE')),
    db.Column('role_id', db.Integer, ForeignKey(
        'tbl_role.id', ondelete='CASCADE', onupdate='CASCADE'))
)

User表和delete接口

class User(UserMixin, db.Model):
    __tablename__ = 'tbl_user'
    # __table_args__ = {'extend_existing': True}
    # User 是一个保存用户数据的 model
    id = db.Column(db.Integer, 
                    # db.ForeignKey('tbl_roles_users.user_id', onupdate="CASCADE", ondelete="CASCADE"),
                    primary_key=True,
                   nullable=False, autoincrement=True)
    name = db.Column(db.String(32), unique=True)
    _passwd = db.Column(db.String(128))
    # passwd = db.Column(db.String(128))
    company = db.Column(db.String(64))
    email = db.Column(db.String(64), unique=True)
    status = db.Column(db.Integer)
    create_time = db.Column(db.TIMESTAMP(True), nullable=False)
    exp_time = db.Column(db.String(50))
    role_id = db.Column(db.Integer)
    phone = db.Column(db.String(16))
    login_count = db.Column(db.Integer, default=0)
    last_login_ip &#
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值