Сортировать результаты MySQL по алфавиту, но с последними номерами - PullRequest
7 голосов
/ 02 мая 2011

Часто сортировка выполняется с помощью символов, отсортированных сверху, например 0 или * или &. Это способ по умолчанию, который сортирует mysql; цифры и символы, а затем A-Z. Однако это приводит к тому, что часто самые уродливые или плохо отформатированные результаты всплывают наверх (например, результат @#$@3423 или 8 inch или &amp).

Итак, я бы хотел изменить его, сначала буквы A-Z, а затем специальные символы.

Как бы мне создать такой тип сортировки? Что-то в предложении ORDER BY?

Ответы [ 3 ]

7 голосов
/ 03 мая 2011

На основе кэшированной в Google ссылки на эту страницу: http://www.google.com/url?sa=t&source=web&cd=3&ved=0CCUQFjAC&url=http%3A%2F%2Fblog.feedmarker.com%2F2006%2F02%2F01%2Fhow-to-do-natural-alpha-numeric-sort-in-mysql%2F&ei=Zg2_TZyKDaffiALjjqwo&usg=AFQjCNGS-rX7AmfrumXK8J7bVSj96bSSmQ

РЕДАКТИРОВАТЬ: исходная ссылка не работает. Вот еще одна ссылка, которая на самом деле объясняет, что происходит лучше, чем первая ссылка:

http://matthewturland.com/2008/11/05/natural-ordering-in-mysql/

Вы можете попробовать это

SELECT names FROM your_table ORDER BY names + 0 ASC
6 голосов
/ 03 мая 2011
Select ...
From ...
Order By Case When Col Like '[0-9]%' Then 1 Else 0 End Asc
    , Col

Другое решение, которое учитывает специальные символы:

Select ...
From ...
Order By Case When Col Like '[A-Z]%' Then 0 Else 1 End Asc
    , Col
0 голосов
/ 22 января 2013

Это работает для меня:

SELECT * FROM `yourTable` ORDER BY `yourDatabase`.`yourColumn`  ASC
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...