字母数字mysql排序

时间:2013-09-29 02:42:58

标签: mysql sql sorting sql-order-by alphanumeric

我知道这已经讨论了很多,而且我已经阅读了大量的q / a来获取。我几乎让它完美但不太完美。以下是我得到的结果和我需要的结果的一个例子。

CMG-1
CMG-1GP
CMG-1EN
CMG-2GP
CMG-2
CMG-2EN
CMG-3 
etc...

我必须订购的代码是

ORDER BY CAST( SUBSTRING( items.item_num, INSTR( items.item_num,  '-' ) +1 ) AS UNSIGNED ) ASC 

这大部分都有效,但在数字之后没有正确排序。前缀是不同的字母和不同的长度,所以它可以忽略前缀。它是在没有正确排序的数字之后。有什么建议吗?

1 个答案:

答案 0 :(得分:0)

尝试:

SELECT item_num
FROM Table1
ORDER BY LEFT(item_num,3)
       , CAST( SUBSTRING(item_num, INSTR(item_num,  '-' ) +1 ) AS UNSIGNED)
       , item_num 
;

演示:SQL Fiddle