我在尝试学习 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 字段,因为如果我删除了项目,它将删除模型。这个想法是项目是临时的,但具有项目的模型是永久性的。
感谢您花时间阅读和回答!