gpt4 book ai didi

mysql - mysql 字母数字排序

转载 作者:行者123 更新时间:2023-11-30 01:15:42 24 4
gpt4 key购买 nike

我知道这个问题已经被讨论了很多,并且我已经阅读了很多问答来了解目前为止的情况。我几乎让它工作完美,但还不是很完美。以下是我得到的结果和我需要的示例。

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 

这在大多数情况下都有效,但无法正确对数字后面的任何内容进行排序。前缀是不同的字母和不同的长度,因此忽略前缀可以正常工作。它位于排序不正确的数字之后。有什么建议吗?

最佳答案

尝试:

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

关于mysql - mysql 字母数字排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19073871/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com