Насколько мне известно, нет способа указать порядок на стороне базы данных таким образом, поскольку он будет слишком специфичным для бэкэнда. Вы можете прибегнуть к старой доброй сортировке Python:
class Foo(models.Model):
name = models.CharField(max_length=128)
Foo.objects.create(name='a10')
Foo.objects.create(name='a1')
Foo.objects.create(name='a2')
ordered = sorted(Foo.objects.all(), key=lambda n: (n[0], int(n[1:])))
print ordered # yields a1, a2, 10
Если вам часто нужна такая сортировка, я бы порекомендовал создать собственный подкласс models.Manager
для вашей модели, который выполняет упорядочение. Что-то вроде:
class FooManager(models.Manager):
def in_a_number_order(self, *args, **kwargs):
qs = self.get_query_set().filter(*args, **kwargs)
return sorted(qs, key=lambda n: (n[0], int(n[1:])))
class Foo(models.Model):
... as before ...
objects = FooManager()
print Foo.objects.in_a_number_order()
print Foo.objects.in_a_number_order(id__in=[5, 4, 3]) # or any filtering expression