zoukankan      html  css  js  c++  java
  • sql server针对字符串型数字排序(针对此字符串的长度不一致)

    对于不规则的字符串数字排序,无法按照数字大的大小排序的原因是,字符串数字在数据库中按照ASCII码排序,从字符的第一个数字对比,首先就会将为首个数字相同的排在一起,在从这些字符串里面对比第二个数字,如下:

    一组字符串为 ‘1’,‘2’,'10','11','3';

    不做任何处理的排序:‘1’,'10','11','2','3';

    解决方法1:

    格式:

    order by 字段名称+数字 的形式进行排序 或者 order by 字段名称*乘以数字的形式进行排序 此时就会按照字符串中的数字排序

    select * from table1 order by  aa+1

    或者 select * from table1 order by  aa*1

    原理:猜想是‘+’或‘*’一个数字之后就会将字符串的数字变为‘+’或‘*’后面数字的类型,此处就会变成int类型。具体的真实原理希望各位能提供

    注:数字为0或1测试有效,其它的数字未测试,MYSql同样适用

    解决方法2:

    select * from table1 order by  len(aa),aa

    原理:将长度一致的字符串先排序,再按照字符串的ASCII码排序

  • 相关阅读:
    win7下jdk安装环境变量配置
    !function($){}(window.jQuery)
    转载几篇
    YeeLink
    坑爹JDK8,可怜的XP
    一致性Hash
    CSS
    仿函数
    launch4j
    GOAL!!!!!!!!!!!!!
  • 原文地址:https://www.cnblogs.com/sugarwxx/p/11859153.html
Copyright © 2011-2022 走看看