Mysql高阶自定义排序

嗨,大家好,我是远码,隔三岔五给大家分享一点工作的技术总结,花费的时间不多,几分钟就行,谢谢!

Mysql对我们码农来说是在熟悉不过的日常了,就不在介绍它的基础用法了,今天我们来简单聊聊它的一个基本高阶使用。

一、问题引入

今天看到一个小伙伴在写一个表查询排序时,整的有点焦头烂额,大致逻辑是这样的:有一个学生表(主要表字段包括,主键:id,姓名:name,阶段:stage),其中stage的值包括(初中、高中、大学),需要按照用户的一下需求指定排序:初中、高总、大学,如果使用系统默认的排序,始终达不到要求,那该如果实现呢?

二、问题解决方式

咋一看,这不就是自定义排序嘛,借此机会就聊聊自定义排序的实现方式吧,大概有以下几种实现方式:

(一)FIELD函数实现

FIELD()函数返回值列表中值的索引位置,语法:FIELD(value, val1, val2, val3, ...),简单的说:改函数就是返回value在集合(val1,val2,val3,...)中对应的索引位置,结合上面的需求,是不是可以这样来使用,学生表stage值就映射函数的value,(初中、高总、大学)就映射函数的值列表集合,如果学生.stage=初中,返回值不是就是1;学生.stage=高中,返回值不是就是2;学生.stage=大学,返回值不是就是3,在对结果值排一个序,不就满足要求了嘛,话不多说上代码:

SELECT id,name,stage FROM `user` ORDER BY FIELD(stage,"初中","高中","大学") asc;

查询结果:搞定

(二)LOCATE函数实现

FIELD(substr,str,pos)函数返回字符串substr在str中第一次出现的位置,pos可空,表示开始坐标,例如:

SELECT LOCATE("初中","初中,高中,大学");--返回1
SELECT LOCATE("高中","初中,高中,大学");--返回2
SELECT LOCATE("大学","初中,高中,大学");--返回3

这不就正好满足上述需求嘛,话不多说上代码:

SELECT id,name,stage FROM `user` ORDER BY LOCATE(stage,"初中,高中,大学") asc;

  

(三)INSTR函数实现

INSTR(str,substr)函数返回字符串str中substr第一次出现的位置,例如:

SELECT INSTR("初中,高中,大学","初中");-- 返回1
SELECT INSTR("初中,高中,大学","高中");-- 返回2
SELECT INSTR("初中,高中,大学","大学");-- 返回3

  

这不就正好满足上述需求嘛,话不多说上代码:

SELECT id,name,stage FROM `user` ORDER BY INSTR("初中,高中,大学",stage) asc;

  

(四)CASE WHEN语句实现

CASE WHEN简单的说就是根据不同的条件将其转换为指定的值,比如:根据stage 的不同值转换为对应的数字,在对结果排序满足要求了,话不多说上代码:

SELECT id,name,stage FROM `user` ORDER BY

CASE stage

   WHEN "初中" THEN 1

WHEN "高中" THEN 2

WHEN "大学" THEN 3

   ELSE 4 END  asc;

  

(五)数据表字典实现

数据表字典思路就是需要单独建立一个stage 的值映射对应关系表,最后通过关联查询,并对根据映射值排序,正好能够满足上述要求,话不多说上代码:

SELECT u.id,u.name,u.stage FROM `user` as u  

JOIN stage_dic as sd on u.stage = sd.stage

ORDER BY sd.code asc;

  

三、问题总结

通过上面的5种排序,都能够解决问题引入提到的自定义排序需求。这5种排序,既有相同的应用场景,也有各自不同的应用场景,在实际使用中还需要根据实际情况选择不同的排序方式,下面对其做一个简单的总结:

  1. 针对简单枚举值皆可实现,数字表字典更灵活
  2. LOCATE与INSTR最终效果一致,参数颠倒,INSTR区分大小写,LOCATE不区分大小写
  3. 函数虽好,使用需要谨慎,能够在存储时就处理好数据,就不要在查询时通过函数计算来解

END
为了更高的交流,欢迎大家关注我的公众号,扫描下面二维码即可关注,谢谢:

Mysql高阶自定义排序的更多相关文章

  1. 高阶自定义View --- 粒子变幻、隧道散列、组合文字

    高阶自定义View --- 粒子变幻.隧道散列.组合文字 作者:林冠宏 / 指尖下的幽灵 掘金:https://juejin.im/user/587f0dfe128fe100570ce2d8 博客:h ...

  2. MySQL 数据库SQL语句——高阶版本1

    MySQL 数据库SQL语句--高阶版本 实验准备,数据表配置 mysql -uroot -p show databases; create database train_ticket; use tr ...

  3. MySQL 数据库SQL语句——高阶版本2

    MySQL 数据库SQL语句--高阶版本2 实验准备 数据库表配置: mysql -uroot -p show databases; create database train_ticket; use ...

  4. 高阶函数,柯里化,sort排序

    高阶函数概念 first class object:     函数在python中时一等公民.     函数也是对象,可调用的对象.     函数可以作为普通变量,参数,返回值等等. 高阶函数:    ...

  5. python高阶函数——sorted排序算法

    python 内置的sorted()函数可以对一个list进行排序: >>> sorted([8,3,8,11,-2]) [-2, 3, 8, 8, 11] 既然说是高阶函数,那么它 ...

  6. MySQL使用order by field()自定义排序

    MySQL的自定义排序和Oracle相比,要简单得多. 假设在表v_education的列schoolRecord中,有以下字段:'小学','初中','高中','专科','本科','硕士','博士'. ...

  7. mysql如何用order by 自定义排序

    mysql如何用order by 自定义排序 id name roleId aaa bbb ccc ddd eee ,MySQL可以通过field()函数自定义排序,格式:field(value,st ...

  8. mysql查询区分大小写与自定义排序

    mysql查询区分大小写: SELECT id,developer FROM products WHERE developer != '' and developer = binary('LYNN') ...

  9. mysql 自定义排序顺序

    mysql 自定义排序顺序 实例如:在sql语句中加入ORDER BY FIELD(status,3,4,0,2,1)语句可定义排序顺序 SELECT tsdvoucher0_.VOUCHER_ID ...

  10. MySQL自定义排序函数FIELD()

    MySQL可以通过field()函数自定义排序,格式:field(value,str1,str2,str3,str4),value与str1.str2.str3.str4比较,返回1.2.3.4,如遇 ...

随机推荐

  1. Clumpify:能使 Fastq 压缩文件再缩小 30% 并加速后续分析流程

    由于微信不允许外部链接,你需要点击文章尾部左下角的 "阅读原文",才能访问文中链接. Clumpify 是 BBMap 工具包中的一个组件,它与其他工具略有不同的是 Clumpif ...

  2. Ubuntu 对比 CentOS 后该如何选择?

    大家阅读完以上文章觉得如何选择更适合自己?欢迎留言哦~ 本文章转载自 Linux 就该这么学(ID: linuxprobe),文章图片与文字版权属源公众号所有,未经允许,禁止二次转载. 我要投稿 本公 ...

  3. Vue3从入门到精通(二)

    vue3 侦听器 在Vue3中,侦听器的使用方式与Vue2相同,可以使用watch选项或$watch方法来创建侦听器.不同之处在于,Vue3中取消了immediate选项,同时提供了新的选项和API. ...

  4. Python之Excel表格数据处理

    正式开讲之前,我们需要先了解几个基本的知识点:1.Python字典(Dictionary) 的setdefault()方法描述:如果键不存在于字典中,将会添加键并将值设为默认值.语法:dict.set ...

  5. [Java SE] 彻底搞懂Java程序的三大参数配置途径:系统变量与JVM参数(VM Option)/环境变量/启动程序参数args

    0 序言 一次没搞懂,处处受影响.这个问题属于基础问题,但又经常踩坑,不得不重视一下了. 1 Java程序动态参数的配置途径:系统变量与JVM参数(VM Option) vs 环境变量 vs 启动程序 ...

  6. java后端接入微信小程序登录功能

    前言 此文章是Java后端接入微信登录功能,由于项目需要,舍弃了解密用户信息的session_key,只保留openid用于检索用户信息 后端框架:spring boot 小程序框架:uniapp 流 ...

  7. 14. SpringMVC执行流程

    14.1.SpringMVC 常用组件 DispatcherServlet:前端控制器,不需要工程师开发,由框架提供 作用:统一处理请求和响应,整个流程控制的中心,由它调用其它组件处理用户的请求 Ha ...

  8. AR技术的应用与未来

    目录 随着科技的不断进步,增强现实(AR)技术也在不断发展壮大.AR技术是一种通过计算机技术和传感器技术将虚拟信息融合到现实世界中的技术,可以为用户带来一种全新的.交互性更强的体验.本文将探讨AR技术 ...

  9. 国标GB28181协议客户端开发(三)查询和实时视频画面

    国标GB28181协议客户端开发(三)查询和实时视频画面 本文是<国标GB28181协议设备端开发>系列的第三篇,探讨了信息查询和实时视频在GB28181协议中的应用.首先,介绍了设备目录 ...

  10. Unity的IPostGenerateGradleAndroidProject:深入解析与实用案例

    Unity IPostGenerateGradleAndroidProject Unity是一款流行的跨平台游戏引擎,它支持多种平台,包括Android.在Unity中,我们可以使用IPostGene ...