django中models字段的联合限制

本文介绍了一种在数据库表设计中对字段联合使用的限制设置方法。具体为:当A字段为true时,B字段必须填写vip等级,否则将抛出异常。通过在表类中重写save方法并进行条件判断实现。

.字段联合使用的限制设置:

有这么个需求,现有两个字段,A字段是选择用户是不是vip, B字段是统计用户的vip等级; 要求:

用户不是vip,A选择false,B字段为空; vip,A字段选择true,B字段就必须填用户的vip等级!

B字段可为空,A字段须是true,B字段就必须有值,否则后续查询就必然出错,所以单单使用

字段属相能否为空无法限制.解决:利用对象的save()方法,我们可自定义save,然后再调用父类该

方法之前做个判断,不满足要求就抛出异常,代码如下:(在表类中重写且继承父类)

 

二.代码如下:

def save(self, *args, **kwargs):
    if self.A == True:
        if not self.B:
            raise ValueError("B字段此时必须有值")
    super(Course, self).save(*args, **kwargs)  # 调用真正的save方法

转载于:https://www.cnblogs.com/quzq/p/10023010.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值