首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >限制Django中外键关系的数量

限制Django中外键关系的数量
EN

Stack Overflow用户
提问于 2020-07-28 08:25:50
回答 1查看 39关注 0票数 0

在django中可以有最大数量的外键关系吗?

例如,我希望一个用户发布的帖子不超过10篇。我初始化模型

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
class Post(models.Model):
    owner = models.ForeignKey(User, on_delete=models.CASCADE)

我应该在哪里添加这张支票?或者这是不可能的,我应该把它放在视线中?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-07-28 08:33:55

以下是我将如何做到这一点。

每个模型都有一个save()选项,保存模型时会调用该选项。你可以在这里检查,如果用户已经有10个帖子,你可以提出一个错误。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
class Post(models.Model):
    owner = models.ForeignKey(User, on_delete=models.CASCADE)
    def save(self,*args, **kwargs):
        if self.id == None: #Creating a new object
            if Post.objects.filter(owner=request.user).count() >= 10:
                #Raise whatever error you want or just return false
        return super(Post, self).save(*args, **kwargs)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63129944

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文