Python Django ORM JOIN postgresql类型转换

Python Django ORM JOIN postgresql类型转换,python,django,postgresql,generic-foreign-key,Python,Django,Postgresql,Generic Foreign Key,我试图使用Django的反向泛型关系通过Django的ORM访问和过滤相关对象。见以下声明的型号: from django.contrib.contenttypes.fields import GenericForeignKey, GenericRelation from django.contrib.contenttypes.models import ContentType from django.db import models class Status(models.Model):

我试图使用Django的反向泛型关系通过Django的ORM访问和过滤相关对象。见以下声明的型号:

from django.contrib.contenttypes.fields import GenericForeignKey, GenericRelation
from django.contrib.contenttypes.models import ContentType
from django.db import models


class Status(models.Model):
    name = models.CharField(max_length=100)

    def __str__(self):
        return self.name


class Package(models.Model):
    name = models.CharField(max_length=500)
    status = models.ForeignKey(Status, on_delete=models.PROTECT)
    hst_entries = GenericRelation("myapp.StatusHistory", related_query_name="package")

    def __str__(self):
        return self.name


class StatusHistory(models.Model):
    content_type = models.ForeignKey(ContentType, on_delete=models.PROTECT)
    object_id = models.TextField()
    object = GenericForeignKey("content_type", "object_id")
    status = models.ForeignKey(Status, on_delete=models.PROTECT)
    entry_added = models.DateTimeField(auto_now_add=True)

    def __str__(self):
        return f"{self.content_type} - {self.object_id}: {self.status.name}"
正如您所看到的,
Package
StatusHistory
模型之间存在通用关系。对于从
StatusHistory
model访问相关软件包,我尝试了:

StatusHistory.objects.filter(package__name__startswith="pack")
结果:

ProgrammingError: operator does not exist: text = integer
LINE 1: ...kage" ON ("myapp_statushistory"."object_id" = "myapp...
                                                             ^
HINT:  No operator matches the given name and argument types. You might need to add explicit type casts.
据我所知,PostgreSQL正在抱怨
object\u id
(属于
StatusHistory
model)和
id
(属于
Package
model)字段之间的类型不匹配。此不匹配可以通过PostgreSQL cast运算符
解决,如下所示:

### WRONG
join myapp_package on (myapp_statushistory.object_id = my_app_package.id)

### RIGHT
join myapp_package on (myapp_statushistory.object_id = my_app_package.id::varchar)
有没有可能通过Django的ORM制作这样的铸件


注意:
object\u id
字段转换为
IntegerField
对我来说不是一个选项。

问题是
的主键不是
文本字段
,因此类型存在问题。您可以为
程序包定义
id=models.TextField(主键=True)
。但现在这两个字段根本不匹配。@WillemVanOnsem除了在数据库中匹配这两个字段的类型之外,没有其他解决方案吗?我正在寻找一种在不改变表的情况下通过Django的ORM解决这个问题的方法。不,Django连接逻辑不允许强制转换。我也认为诚实的铸造是坏的设计,因为这两种类型有不同的等价关系。例如,在整数字段中,
001
1
是相同的,但在文本字段中,
'001'
'1'
是不同的。因此,它使单一性约束变得不可能。