sql server 针对字符串型数字排序(解决方法)

对于不规则的字符串数字排序,无法按照数字大的大小排序的原因是,字符串数字在数据库中按照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

posted @   fanguoan  阅读(2132)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
点击右上角即可分享
微信分享提示