繁体   English   中英

Django Multiple ForeignKey和相同的相关名称

[英]Django Multiple ForeignKey and same related name

我想将user键用于许多模型。 我不能使用这种方法。 是否有可能为所有外键提供通用名称。 我想在每个模板中访问x.createdx.updated

class Model_one(models.Model):
    --
    --
    created = models.ForeignKey(User,related_name="created")
    updated = models.ForeignKey(User,related_name="updated")


class Model_two(models.Model):
    --
    --
    created = models.ForeignKey(User,related_name="created")
    updated = models.ForeignKey(User,related_name="updated")


class Model_three(models.Model):
    --
    --
    created = models.ForeignKey(User,related_name="created")
    updated = models.ForeignKey(User,related_name="updated")

为了概括你的方法,你可以做类似的事情:

class BaseModel(models.Model):
    created = models.ForeignKey(User,related_name="created_%(class)s_objects")
    updated = models.ForeignKey(User,related_name="updated_%(class)s_objects")

    class Meta:
        abstract = True


class ModelOne(BaseModel):
    # your model one fields


class ModelTwo(BaseModel):
    # your model two fields

用这种方法你

  • 不需要显式定义所有模型上的相同字段,因为您从BaseModel继承。

  • 特殊语法自动创建具有正确类名的后向关系。 因此user.created_modelone_objects.all()将为您提供用户创建的所有对象。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM