我知道这已经讨论了很多,而且我已经阅读了大量的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
这大部分都有效,但在数字之后没有正确排序。前缀是不同的字母和不同的长度,所以它可以忽略前缀。它是在没有正确排序的数字之后。有什么建议吗?
答案 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