• SQL实现自定义排序


    业务事实上,经常会遇到排序问题,对数值类型字段排序不会有很大争议,但是有时希望对字符型字段按要求进行排序。本文记录自定义排序的几种方法。

    使用case when关键字进行限定

    本方法思路是将希望排序小的字符取值为较小的数字。注意end后面不要加as起别名。

    select 
    	*
    from
    	tableName
    order by
    case order_field when '超期0-5天' then 1
                     when '超期6-10天' then 2
                     when '超期11-15天' then 3
                     when '超期16-20天' then 4
                     when '超期21天及以上' then 5
    end
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    field函数

    field(str,str1,str2,…)函数可以返回str在str1,str2…列表中的位置,如果不存在返回结果0

    select field('很好','很好','不好')  --结果:1
    select field('不好','很好','不好')  --结果:2
    select field('你好','很好','不好')  --结果:0
    select field(null,'很好','不好')  --结果:0
    
    • 1
    • 2
    • 3
    • 4

    str字符串可以替换为字段名,进而判断每个取值在列表中的排序,只要将列表按需求写好就可以实现自定义排序。

    select 
    	*
    from
    	tableName
    order by field(order_field,'超期0-5天','超期6-10天','超期11-15天','超期16-20天','超期21天及以上')
    
    • 1
    • 2
    • 3
    • 4
    • 5
    字符串位置定位函数

    这种方法的思路是,定位字符串在一个长串中的位置,返回的位置号是有大小的,长字符串按照要求写好就可以。

    select locate('超期0-5天','超期0-5天,超期6-10天,超期11-15天,超期16-20天,超期21天及以上')  --返回结果:1
    select locate('超期6-10天','超期0-5天,超期6-10天,超期11-15天,超期16-20天,超期21天及以上')  --返回结果:8
    select instr('超期0-5天,超期6-10天,超期11-15天,超期16-20天,超期21天及以上','超期0-5天')  --返回结果:1
    select instr('超期0-5天,超期6-10天,超期11-15天,超期16-20天,超期21天及以上','超期6-10天')  --返回结果:8
    
    • 1
    • 2
    • 3
    • 4

    将字符串改为字段名

    select 
    	*
    from
    	tableName
    order by locate(order_field,'超期0-5天,超期6-10天,超期11-15天,超期16-20天,超期21天及以上')
    
    • 1
    • 2
    • 3
    • 4
    • 5
  • 相关阅读:
    SpringDataJpa(三)
    危化品安全生产风险监测预警系统的构建与实施
    会议OA项目之我的审批功能
    swift的lazy关键字 后面还会补充
    大数据、小数据、都要从养数据开始
    2022年深圳技能大赛-大数据技术应用职业技能竞赛介绍
    源码分析:Transport 开发
    【LeetCode-112】路径总和
    三维重建---第四章 三维重建及极几何
    java计算机毕业设计校园二手交易平台的设计源程序+mysql+系统+lw文档+远程调试
  • 原文地址:https://blog.csdn.net/weixin_50646402/article/details/133887017