Django ORM QuerySet 根据指定字段,指定条件排序
借助extra
方法使用sql语句对结果重新排序
pk_list是按照指定条件、自定义序列过滤出来的主键
可以使用sorted
函数排列成我们想要的顺序
-
第一种方法
mysql中的sql语句(降序)select * from X ORDER BY FIELD(id, '1', '2', '3', '5', '6', '4') DESC
升序
pk_list = [10,2,1] ordering = 'FIELD (`id`, %s)' % ','.join(str(id) for id in pk_list) queryset = X.objects.filter(pk__in=[pk_list]).extra(select={'ordering': ordering}, order_by=('ordering',))
降序
pk_list = [10,2,1] ordering = 'FIELD (`id`, %s)' % ','.join(str(id) for id in pk_list) queryset = X.objects.filter(pk__in=[pk_list]).extra(select={'ordering': ordering}, order_by=('-ordering',))
-
第二种方法
mysql中的sql语句(升序)
SELECT * FROM X ORDER BY (CASE WHEN id=1 THEN 0 WHEN id=5 THEN 1 WHEN id=3 THEN 2 WHEN id=2 THEN 3 WHEN id=4 THEN 4 END) ASC
升序降序同理
pk_list = [10, 2, 1] clauses = ' '.join(['WHEN id=%s THEN %s' % (pk, i) for i, pk in enumerate(pk_list)]) ordering = 'CASE %s END' % clauses queryset = X.objects.filter(pk__in=pk_list).extra(select={'ordering': ordering}, order_by=('ordering', ))
方法一的查询速度更快一下