[英]Complex ordering in django db query
我的数据库中有以下条目:
`title` `status`
Titanic WIP
Avatar WIP
Terminator Complete
Abyss Default
我想根据对象的状态对这些对象进行排序:默认,然后是WIP,然后是完成。 那么正确的顺序是:
Abyss / Default
Avatar / WIP
Titanic / WIP
Terminator / Complete
我该如何进行以下数据库调用?
Title.objects.order_by(status='Default', status='WIP', status='Complete',title)
要执行此查询,您可以使用django的extra
:
titles = Title.objects.all()
ordered_query = titles.extra(select={
'ordering':"(
case when status='Default' then 1
when status='WIP' then 2
when status='Complete' then 3
end)"
}).order_by('ordering', 'title')
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.