对于不规则的字符串数字排序,无法按照数字大的大小排序的原因是,字符串数字在数据库中按照ASCII码排序,从字符的第一个数字对比,首先就会将为首个数字相同的排在一起,在从这些字符串里面对比第二个数字,如下:
一组字符串为 ‘1’,‘2’,'10','11','3';
不做任何处理的排序:‘1’,'10','11','2','3';
解决方式1:
order by 字段名称+数字 的形式进行排序
或者 order by 字段名称*乘以数字的形式进行排序 此时就会按照字符串中的数字排序
select * from tab1 order by aa+1
或者 select * from tab1 order by aa*1
原理:猜想是‘+’或‘*’一个数字之后就会将字符串的数字变为‘+’或‘*’后面数字的类型,此处就会变成int类型。具体的真实原理希望各位能提供
注:数字为0或1测试有效,其它的数字未测试,MYSql同样适用
解决方式2:
select * from table1 order by len(aa),aa
原理:将长度一致的字符串先排序,再按照字符串的ASCII码排序
原文链接:https://www.likecs.com/show-307907977.html