0

我知道这已经讨论了很多,并且我已经阅读了很多 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 

这在大多数情况下都有效,但在数字之后没有正确排序任何东西。前缀是不同的字母和不同的长度,因此忽略前缀可以正常工作。它在排序不正确的数字之后。有什么建议么?

4

1 回答 1

0

Try:

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

Demo: SQL Fiddle

于 2013-09-29T03:20:02.917 回答