0


我创建了一个通用外键,以便能够以通用方式引用 Report 模型中的任何类型(A 或 B)模型。
它工作正常,但我的问题是现在,我需要进行查询以检索所有引用特定类型模型的报告实例(例如,所有具有引用类 A 的外键的报告)。我试图访问数据库中的 content_type 但显然不可能(变量不存在......)
这是我的模型:

class Report(models.Model):
  content_type = models.ForeignKey(ContentType)
  object_id = models.CharField(max_length=50)
  reported_item = generic.GenericForeignKey('content_type', 'object_id')

class A(models.Model):
  reports = generic.GenericRelation(Report)

class B(models.Model):
  reports = generic.GenericRelation(Report)

你知道怎么做吗?
以防万一它会改变任何东西,我使用 mongoDB 作为我的数据库。
非常感谢!

编辑:
当我在数据库中显示报告对象时,结果如下:

db.website_report.findOne()
{
"_id" : ObjectId("50afa903a96c5c2f63000001"),
"content_type_id" : ObjectId("50afa903a96c5c2f63000000"),
"object_id" : "50afa8a8a96c5c2f53000001",
}

如您所见,数据库的内容与我的模型没有任何相似之处,所以我不知道如何进行查询以获取所有具有外键 A 的报告。
您能帮帮我吗?

4

3 回答 3

3

我不明白你为什么认为 db 不能反映你的模型。那里有内容类型引用和对象 ID。您需要做的只是找出什么内容类型引用了您的模型 A,内容类型文档中对此进行了说明:

ct = ContentType.objects.get_for_model(A)
objs = Report.objects.filter(content_type=ct)
于 2012-11-24T23:17:59.140 回答
0

这是我的一个项目中的一个示例类,它显示了某些模型和使用 Q 对象的应用程序的限制

class ContainerItem(models.Model) :
    """Items for containers"""
    limit = models.Q(model="page") & (models.Q(app_label='events') | models.Q(app_label='press')) & ~models.Q(app_label='press', model='category')
    object_type = models.ForeignKey(ContentType, limit_choices_to=limit)
    object_id = models.IntegerField(db_index=True)
    object = generic.GenericForeignKey(
        ct_field = "object_type", 
        fk_field = "object_id"
    )
于 2012-11-24T23:19:31.500 回答
-1

无法过滤 GenericForeignKeys:

由于 GenericForeignKey 的实现方式,您不能通过数据库 API 直接将此类字段与过滤器(例如 filter() 和 exclude())一起使用。因为 GenericForeignKey 不是普通的字段对象,所以这些示例将不起作用:

于 2012-11-24T22:49:01.440 回答