MySQL - 将子字符串数字从最低到最高排序

MySQL - Order substring digits lowest to highest

我想按值从低到高对列进行排序。但是该列有一个前缀集,所以它的内容看起来像这样 SR1001000。我想如果我想订购这个,我需要删除前缀。所以现在我的查询看起来像这样:

SELECT a2t_import.*,SUBSTRING(a2t_import.a2t_vare_nr, 3) as partial_vare_nr 
FROM a2t_import 
ORDER BY partial_vare_nr ASC`

但是我也只需要获取列具有特定前缀的行,我可以通过添加像这样的正则表达式来获取前缀

SELECT a2t_import.*,SUBSTRING(a2t_import.a2t_vare_nr, 3) as partial_vare_nr 
FROM a2t_import 
WHERE a2t_vare_nr REGEXP '^(SR)+[0-9]+' 
ORDER BY partial_vare_nr ASC

这给了我正确的输出,上面的例子看起来像这样 1001000,但是排序不是我所期望的。

我得到以下输出

10002000
1001000
...

如您所见,第一行的数字明显高于第二行。这是为什么?

当前 MySQL 将您的计算列视为文本而不是数字数据,导致排序关闭的原因。这具有以下不良副作用:

10002000
1001000
   ^

10002000 首先出现,因为它会出现在字典中的 1001000 之前。解决此问题的一个技巧是在排序时也使用字符串的长度。考虑以下比较:

1000200
1001000

现在1000200排在1001000之前,字典排序与数字排序一致。

尝试以下查询:

SELECT a2t_import.*,
       SUBSTRING(a2t_import.a2t_vare_nr, 3) AS partial_vare_nr
FROM a2t_import
WHERE a2t_vare_nr REGEXP '^(SR)+[0-9]+'
ORDER BY CHAR_LENGTH(partial_vare_nr),     -- shortest strings first
         partial_vare_nr                   -- lexigraphical sort among strings
                                           -- of same length - agrees with numeric sort