码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 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
  • 相关阅读:
    云计算与数字化转型的关系,终于有人讲明白了
    【李沐论文精读】GPT、GPT-2和GPT-3论文精读
    【JavaWeb学习】—手托html页面和在浏览器中输入地址访问的背后不同原因(十一)
    (数字图像处理MATLAB+Python)第十二章图像编码-第三、四节:有损编码和JPEG
    Dubbo总概
    C# 第二章『基础语法』◆第2节:switch case语句
    计算机网络-物理层
    html5期末大作业——HTML+CSS公益关爱残疾人( 6个页面)
    AI技术:分享8个非常实用的AI绘画网站
    YOLOv8改进全新Inner-IoU损失函数:全网首发|2023年11月最新论文|扩展到其他SIoU、CIoU等主流损失函数,带辅助边界框的损失
  • 原文地址:https://blog.csdn.net/weixin_50646402/article/details/133887017
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号