![](/img/trans.png)
[英]django - using of related_name in ManyToMany and in ForeignKey
[英]Django Multiple ForeignKey and same related name
我想将user
键用于许多模型。 我不能使用这种方法。 是否有可能为所有外键提供通用名称。 我想在每个模板中访问x.created
或x.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.