table Picture with rows have name
1.jpg,2.jpg,3.jpg,4.jpg,5.jpg,6.jpg,7.jpg,8.jpg,9.jpg,10.jpg,11.jpg
select * from Picture order by name
mysql order : 1.jpg,10.jpg,11.jpg,2.jpg,3.jpg,......
Issue:
I want it sort all type name like as开发者_StackOverflow社区 with Window 1.jpg,2.jpg,3.jpg,4.jpg,5.jpg,6.jpg,7.jpg,8.jpg,9.jpg,10.jpg,11.jpg
and it must working with other case as
flower01.jpg,flower02.jpg,flower031.jpg,....,flower10.jpg
please help me
You basically have 4 choices.
- Change name to a numeric type, and remove the .jpg (adding it later in code)
- Add an 'order' column and sort by that
- Sort it in your code, not in SQL
- Use of the of the cast 'hacks' (e.g. CAST(NAME AS UNSIGNED)
A hackish way to do it:
... ORDER BY CAST(name AS UNSIGNED);
Edit: an alternative would be:
... ORDER BY LPAD(name,N,'0');
Where N
is the maximum width of your column.
Sadly, MySQL doesn't support natural sorting natively AFAIK.
ODER BY name sees that name is a string and sorts it accordingly,charater by character. You have to make MySQL interpret the name as numeric value. A way might be something like this:
select * from Picture order by name * 1;
精彩评论