SQL实现自定义排序

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

使用case when关键字进行限定

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

sql 复制代码
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
field函数

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

sql 复制代码
select field('很好','很好','不好')  --结果:1
select field('不好','很好','不好')  --结果:2
select field('你好','很好','不好')  --结果:0
select field(null,'很好','不好')  --结果:0

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

sql 复制代码
select 
	*
from
	tableName
order by field(order_field,'超期0-5天','超期6-10天','超期11-15天','超期16-20天','超期21天及以上')
字符串位置定位函数

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

sql 复制代码
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

将字符串改为字段名

sql 复制代码
select 
	*
from
	tableName
order by locate(order_field,'超期0-5天,超期6-10天,超期11-15天,超期16-20天,超期21天及以上')
相关推荐
2501_948195344 小时前
RN for OpenHarmony英雄联盟助手App实战:主导航实现
数据库
Filotimo_5 小时前
N+1查询问题
数据库·oracle
fenglllle6 小时前
spring-data-jpa saveall慢的原因
数据库·spring·hibernate
DarkAthena7 小时前
【GaussDB】执行索引跳扫时如果遇到该索引正在执行autovacuum,可能会导致数据查询不到
数据库·gaussdb
短剑重铸之日7 小时前
《7天学会Redis》Day 5 - Redis Cluster集群架构
数据库·redis·后端·缓存·架构·cluster
007php0077 小时前
mySQL里有2000w数据,Redis中只存20w的数据,如何保证Redis中的数据都是热点数据
数据库·redis·git·mysql·面试·职场和发展·php
lkbhua莱克瓦247 小时前
进阶-存储过程3-存储函数
java·数据库·sql·mysql·数据库优化·视图
老邓计算机毕设8 小时前
SSM心理健康系统84459(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·心理健康系统·在线咨询
碎像8 小时前
10分钟搞定 MySQL 通过Binlog 数据备份和恢复
数据库·mysql