时间:2021-05-24
ORDER BY 字段名 升序/降序,相信进来的朋友都认识这个排序语句,但遇到一些特殊的排序,单单使用字段名就无法满足需求了,下面给大家介绍几个我遇到过的排序方法:
为了更好演示与理解,先准备一张学生表,加入编号、姓名、成绩三个字段,插入几条数据,如图:
需求一:成绩从高到低进行排序
街边卖菜的阿姨都能敲,直接使用 ORDER BY examScore DESC 轻松完成了(如下左图)。
需求二:成绩从高到低进行排序,并且没录入成绩的排在最前面
客户体验最重要,为了方便二次录入成绩,提出这样的需求纯属正常。要实现该排序,上面的语句是无法实现的,因此就需要用到条件排序,先判断成绩为空赋个最大值,再进行排序,如 ORDER BY IF(examScore IS NULL,101,examScore) DESC 也能轻松实现(如下右图)。
需求 需求一 需求二 语句 ORDER BY examScore DESC ORDER BY IF(examScore IS NULL,101,examScore) DESC 效果客户如上帝,需求花里胡哨也屡见不鲜,就比如,要求张三李四排在最前面,其他学生按照成绩从高到低进行排序。这种情况就需要使用自定义排序了,MySQL 自带的 FIELD 函数(返回对应字符串的索引)可帮您实现。
语句一:
ORDER BY FIELD(studentName,‘张三',‘李四') ASC, examScore DESC;
上面语句运行结果却把张三李四排到最后了(如下左图),顺理成章的,要把张三李四编排到最前面就进行降序排序。
语句二:
ORDER BY FIELD(studentName,‘李四',‘张三') DESC, examScore DESC;
结果果然正中下怀(如下右图)。
语句 语句一 语句二 效果后来发现 FIND_IN_SET 函数也能实现,而且使用100万条数据测试,FIND_IN_SET 性能更优。
ORDER BY FIND_IN_SET(studentName,‘李四,张三') DESC, examScore DESC;
有些朋友就奇怪了,汉字排序直接使用普通的 ORDER BY 字段 ASC 轻松完事啦,为什么说鲜为人知呢。
其实,用户创建表字段使用 GBK 字符集时,直接使用ORDER BY 字段 ASC 可以迎刃而解,有些用户为了防止乱码,使用了 utf8 字符集,简单的排序语句就无能为力了(如下左图),因此在排序时把字段转换为 GBK 就OK了(如下右图)。
语句 ORDER BY studentName ASC ORDER BY CONVERT(studentName USING GBK) ASC 效果
到此这篇关于MySQL中一些鲜为人知的排序方式的文章就介绍到这了,更多相关MySQL排序方式内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文为你介绍MySQL中十条鲜为人知的技巧。MySQL易学易用,且附带丰富的技术文档,这二个因素使之被广泛应用。然而,随着MySQL发展之迅速,即使一个MySQ
本文将介绍一些鲜为人知的Excel2007操作技巧,它们将帮助您更加高效地使用Excel。它们主要是针对启动Excel2007时默认的设置作改进,从而使得Exc
除了点击开关机键,windows还隐藏哪些有趣但鲜为人知的开关机方式呢?那么接着往下看吧! 关机篇: 滑动关机 滑动关机是Win10内置的一个小命令,
邮件营销看上去容易,实际上却很难。i黑马整理了一些简单但鲜为人知的邮件营销策略来帮助使用这些方法的人获得更高的邮件打开率和转化率。希望对创业者的邮件营销提供帮助
除了点击开关机键,windows还隐藏哪些有趣但鲜为人知的开关机方式呢?那么接着往下看吧! 关机篇: 滑动关机 滑动关机是Win10内置的一个小命令,