开发者

Django自定义排序ORM示例详解

Django 模型数据排序

在 Django 编程客栈中,打算对模型数据排序,但排序的方式是需要自定义的。有三种方式

  • 将数据读取到内存之后,利用python自带的排序方式进行排序。
  • 利用 Case-When 技术,让数据库来完成排序。

例如,模型如编程客栈

class ItemType(TextChoices):  
    A = '选择题', '选择题'  
    B = '填空题', '填空题'  
    C = '简单题', '简单题'  
class www.devze.comItem(models.Model):
    type = models.CharFielwww.devze.comd(choices=options.ItemType.choices)

可以这样定义排序映射:

from django.db.models import  Case, Value, When
type_order = Case(  
    When(type=ItemType.A, then=Value(0)),  
    When(type=ItemType.B, then=Value(1)),  
    When(type=ItemType.C, then=Value(2)),  
)
Item.objects.alias(type_order=tydwvuUpe_order).order_by(type_order)

这种方式,要比第一种方式更加高效。

  • 定义 choices 时,存入数据的值是有顺序的,利用 choices 映射为显示值。这种方式很直观,效率更高,但缺点是需要多一次映射。

以上就是Django自定义排序ORM示例详解的详细内容,更多关于Django自定义排序ORM的资料请关注编程客栈(www.devze.com)其它相关文章!

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新开发

开发排行榜