django中当model设置了ordering后,使用distinct()和annotate()问题记录

本文记录了在Django中,当Model设置`ordering`属性后,使用`annotate()`和`distinct()`出现的问题。在Model的Meta类中设置了`ordering = ['-date_create']`,导致在按`host_name`分组时,SQL在`GROUP BY`中包含了`date_create`,影响了预期结果。解决方法是移除`ordering`设置,以使代码正常运行。
摘要由CSDN通过智能技术生成

model类如下,我在class Meta中设置了ordering = ['-date_create'],即模型对象返回的记录结果集是按照这个字段排序的。

class SystemUserPushHistory(models.Model):

    id = models.UUIDField(default=uuid.uuid4, primary_key=True)
    host_name = models.CharField(max_length=128, null=False)
    system_username = models.CharField(max_length=128, null=False)
    method = models.CharField(max_length=32, null=False)
    is_success = models.BooleanField(default=False)
    date_create = models.DateTimeField(auto_now_add=True, editable=False)
    message = models.CharField(max_length=4096, null=True)

    class Meta:
        db_table = "assets_systemuser_push_history"
        ordering = ['-date_create']

    def __str__(self):
        ret = self.system_username + " => " + self.host_name
        return ret

 当业务有

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值