4

我想知道是否有一种方法可以将 datetime auto_now_add=True 列添加到 manytomany 字段。我有以下模型。

class Photographer(models.Model):
     user = models.OneToOneField(User, primary_key=True)
     bio = models.CharField(max_length=140, blank=True)
     favorites = models.ManyToManyField('Photo', through='Favorites', related_name = 'photographer_favs')
     likes = models.ManyToManyField('Photo', related_name='likedby', blank=True)

在我的 postgresql 数据库中,我有一个单独的表,称为“djangoapp_摄影师_likes”。

在这张表中,我有三列:

id                 photographer_id        photo_id
[PK] serial        integer                integer
    1                  3                    6
    2                  3                    7
    3                  3                    8

在投入生产几个月后,我意识到我需要知道我们喜欢这些照片的日期时间。因此,我将有四列,而不是三列:

    id             photographer_id        photo_id      liked
[PK] serial        integer                integer       timestamp with time zone
    1                  3                    6           2013-07-10 23:30:19.559463+00
    2                  3                    7           2013-07-11 17:00:53.39614+00
    3                  3                    8           2013-07-11 17:25:28.4953+00

即使它不在模型中,是否可以添加这个额外的列?我想要它,以便每次喜欢一张图片时,都会记录它被点赞的时间。如果这是不可能的,我应该研究哪些其他解决方法?

编辑

这是我的照片模型:

class Photo(models.Model):
     title = models.CharField(max_length=40, blank=True)
     photographer = models.ForeignKey(Photographer, related_name = 'shot_owner')
     postTime = models.DateTimeField(auto_now_add=True)
     description = models.CharField(max_length=255, blank=True)
     url = models.CharField(max_length=128)
4

1 回答 1

8

是的,这很正常。您将为 Likes 关系声明一个显式模型并在其上添加 datetime 字段。检查多对多字段文档以获取完整详细信息和一些示例 - 组成员身份示例包括一个“加入日期”字段,该字段与您的喜欢时间戳相同。auto_now_add=True在字段定义中使用应该自动记录时间戳。

class Photographer(models.Model):
    # as above, but:
    likes = models.ManyToManyField('Photo', through='PhotoLikes', related_name='likedby', blank=True)

class PhotoLikes(models.Model):
    class Meta:
        db_table = 'djangoapp_photographer_likes'
        # or whatever your table is called
    photo = models.ForeignKey(Photo)
    photographer = models.ForeignKey(Photographer)
    liked = models.DateTimeField(null=True, blank=True, auto_now_add=True)

正如文档所指出的,创建喜欢的方法在此设置中受到更多限制:

与普通的多对多字段不同,您不能使用添加、创建或赋值(即 beatles.members = [...])来创建关系

为什么?您不能只在 Person 和 Group 之间创建关系 - 您需要为 Membership 模型所需的关系指定所有细节。简单的 add、create 和 assignment 调用不提供指定这些额外细节的方法。因此,对于使用中间模型的多对多关系,它们被禁用。创建这种类型的关系的唯一方法是创建中间模型的实例。

在这种情况下,理论上可以确定额外的细节,因为它是一个自动时间戳,但 Django 并不能完全检测到这一点。

于 2013-07-22T21:19:25.973 回答