0

我在尝试学习 Django 时正在制作一个基于浏览器的小型游戏。我有很多模型都可以有与之关联的“项目”。

这是可以包含项目的模型之一:

class Bank(models.Model):
    user = models.ForeignKey(User, unique=True)
    cash = models.IntegerField()

我的 Item 类具有通用关系,因此它可以与我需要包含项目的任何模型相关联。它还具有用户的 ForeignKey,因为每个项目都必须由用户拥有:

class Items(models.Model):
    user = models.ForeignKey(User)
    name = models.CharField(max_length=100)
    description = models.TextField()
    itemType = models.CharField(max_length=50)
    stats = models.CommaSeparatedIntegerField(max_length=100)
    content_type = models.ForeignKey(ContentType)
    object_id = models.PositiveIntegerField()
    content_object = generic.GenericForeignKey('content_type', 'object_id')

我的问题是如何获取当前与银行关联的项目列表(或我的任何其他可以拥有项目的模型)?

使用泛型关系是实现此目的的好方法吗?使用多对多关系来做这样的事情会更容易(甚至可能)吗?

我想避免在我的模型中使用可以包含项目的实际 GenericRelation 字段,因为如果我删除了项目,它将删除模型。这个想法是项目是临时的,但具有项目的模型是永久性的。

感谢您花时间阅读和回答!

4

1 回答 1

0

要轻松访问您ItemsBank模型,您可以在模型中提供快捷方式:

class Bank(models.Model):
    ...
    items = generic.GenericRelation(Item)

请注意,这只是 django 知道要查找什么的捷径。如果你删除你BankItems不会受到影响。

于 2013-03-31T23:25:19.510 回答