MySQL 中 FIELD() 自定义排序示例详解

 更新时间:2024年05月14日 09:28:00   作者:Kllin  
MySQL中的field()函数,可以用来对SQL中查询结果集进行指定顺序排序,这篇文章主要介绍了MySQL 中 FIELD() 自定义排序,需要的朋友可以参考下

MySQL 中 FIELD() 自定义排序

在 MySQL 中,你可以使用 ORDER BY FIELD() 来自定义排序顺序。这个函数允许你指定字段的自定义排序顺序,而不是默认的升序或降序排序。以下是一个简单的例子:

假设你有一个表格叫做 products,其中有一个字段叫做 category,你想按照特定的类别顺序进行排序,比如 'Electronics', 'Clothing', 'Books',你可以这样做:

SELECT * FROM products
ORDER BY FIELD(category, 'Electronics', 'Clothing', 'Books');

这个查询会按照 'Electronics''Clothing' 和 'Books' 的顺序来排序 category 字段。

你也可以结合其他的排序条件,比如:

SELECT * FROM products
ORDER BY FIELD(category, 'Electronics', 'Clothing', 'Books'), price ASC;

补充:MySQL中函数field()的用法

MySQL中的field()函数,可以用来对SQL中查询结果集进行指定顺序排序。

函数使用格式如下:

order by (str,str1,str2,str3,str4……),str与str1,str2,str3,str4比较,其中str指的是字段名字,

意为:字段str按照字符串str1,str2,str3,str4的顺序返回查询到的结果集。如果表中str字段值不存在于str1,str2,str3,str4中的记录,放在结果集最前面返回。

例:

表数据如下:

root@localhost|iris>select * from ta;
+----+--------+------+-------+
| id | name   | age  | class |
+----+--------+------+-------+
|  1 | iris   |   11 | a1    |
|  2 | iris   |   22 | a2    |
|  3 | seiki  |   33 | a3    |
|  4 | seiki  |   44 | a4    |
|  5 | xuding |   55 | a5    |
|  6 | xut    |   66 | a6    |
|  7 | iris   |   12 | a2    |
|  8 | iris   |   24 | a4    |
|  9 | seiki  |   36 | a6    |
| 10 | seiki  |   48 | a8    |
| 11 | xuding |   50 | a0    |
| 12 | xut    |   77 | a7    |
+----+--------+------+-------+
12 rows in set (0.00 sec)

按照'seiki','iris','xut'来排序,结果如下:

root@localhost|iris>select * from ta order by field(name,'seiki','iris','xut');
+----+--------+------+-------+
| id | name   | age  | class |
+----+--------+------+-------+#不在str1,str2,str3中的内容,放在最前面返回,str值相同按照主键的顺序
|  5 | xuding |   55 | a5    |
| 11 | xuding |   50 | a0    |
|  3 | seiki  |   33 | a3    |
|  4 | seiki  |   44 | a4    |
|  9 | seiki  |   36 | a6    |
| 10 | seiki  |   48 | a8    |
|  1 | iris   |   11 | a1    |
|  2 | iris   |   22 | a2    |
|  7 | iris   |   12 | a2    |
|  8 | iris   |   24 | a4    |
|  6 | xut    |   66 | a6    |
| 12 | xut    |   77 | a7    |
+----+--------+------+-------+
12 rows in set (0.00 sec)

按照'seiki','iris'来排序,结果如下:

root@localhost|iris>select * from ta order by field(name,'seiki','iris');
+----+--------+------+-------+
| id | name   | age  | class |
+----+--------+------+-------+#不在str1,str2,str3中的内容,放在最前面返回;str值相同按主键顺序排列
|  5 | xuding |   55 | a5    |
|  6 | xut    |   66 | a6    |
| 11 | xuding |   50 | a0    |
| 12 | xut    |   77 | a7    |
|  3 | seiki  |   33 | a3    |
|  4 | seiki  |   44 | a4    |
|  9 | seiki  |   36 | a6    |
| 10 | seiki  |   48 | a8    |
|  1 | iris   |   11 | a1    |
|  2 | iris   |   22 | a2    |
|  7 | iris   |   12 | a2    |
|  8 | iris   |   24 | a4    |
+----+--------+------+-------+
12 rows in set (0.00 sec)

按照'seiki','iris' desc 来排序,结果如下:

root@localhost|iris>select * from ta order by field(name,'seiki','iris') desc;
+----+--------+------+-------+
| id | name   | age  | class |
+----+--------+------+-------+
|  1 | iris   |   11 | a1    |
|  2 | iris   |   22 | a2    |
|  7 | iris   |   12 | a2    |
|  8 | iris   |   24 | a4    |
|  3 | seiki  |   33 | a3    |
|  4 | seiki  |   44 | a4    |
|  9 | seiki  |   36 | a6    |
| 10 | seiki  |   48 | a8    |#倒序时,按照str3,str2,str1的顺序逆向排序,
|  5 | xuding |   55 | a5    |#不在str1,str2,str3中的记录放到最后;str值相同按主键顺序排列
|  6 | xut    |   66 | a6    |
| 11 | xuding |   50 | a0    |
| 12 | xut    |   77 | a7    |
+----+--------+------+-------+

这个查询会先按照指定的类别顺序排序,然后在每个类别内按照价格升序排序。

到此这篇关于MySQL 中 FIELD() 自定义排序的文章就介绍到这了,更多相关MySQL 自定义排序内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL之mysqldump的使用详解

    MySQL之mysqldump的使用详解

    这篇文章主要介绍了MySQL之mysqldump的使用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • mysql按逗号分割的实现

    mysql按逗号分割的实现

    在MySQL中,我们经常需要对数据进行拆分和处理,其中一个常见需求就是按逗号分割字符串,具有一定的参考价值,感兴趣的可以了解一下
    2023-11-11
  • mysql视图原理与用法实例小结

    mysql视图原理与用法实例小结

    这篇文章主要介绍了mysql视图原理与用法,结合实例形式分析了mysql视图的概念、原理、创建、使用方法及相关注意事项,需要的朋友可以参考下
    2018-04-04
  • MySQL 如果单独获取已知日期的年月日

    MySQL 如果单独获取已知日期的年月日

    本文介绍在MySQL中如何使用内置函数提取日期和时间的各个部分,包括年、月、日、小时、分钟、秒以及星期几,通过示例和代码,展示了如何使用YEAR()、MONTH()、DAY()、HOUR()、MINUTE()、SECOND()和WEEKDAY()函数,并介绍了DATE_FORMAT()函数的灵活性,感兴趣的朋友一起看看吧
    2025-01-01
  • 解决Linux下Tomcat向MySQL插入数据中文乱码问题

    解决Linux下Tomcat向MySQL插入数据中文乱码问题

    本文给大家介绍的是如何解决win平台下开发的项目移植到Linux平台后,向MySQL插入数据时中文出现乱码的问题,非常的简单实用,有需要的小伙伴可以参考下
    2018-04-04
  • MySQL中SQL查询常见调优方案对比与实践

    MySQL中SQL查询常见调优方案对比与实践

    文章浏览阅读429次,点赞3次,收藏2次。本文从索引优化、查询重写、分库分表、缓存方案四个角度,对SQL调优进行对比分析,并结合真实生产环境案例验证了各方案的应用效果,为后端开发者提供实用的最佳实践指导。
    2025-07-07
  • MySQL下200GB大表备份的操作(利用传输表空间解决停服发版表备份问题)

    MySQL下200GB大表备份的操作(利用传输表空间解决停服发版表备份问题)

    这篇文章主要介绍了MySQL下200GB大表备份的操作(利用传输表空间解决停服发版表备份问题),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2025-04-04
  • MySQL启动报错提示发生系统错误5,拒绝访问的原因和解决方法

    MySQL启动报错提示发生系统错误5,拒绝访问的原因和解决方法

    使用命令net start mysql启动数据库服务时候,出现如下错误提示发生系统错误5,拒绝访问,所以本文给大家介绍了MySQL启动报错提示发生系统错误5,拒绝访问的原因和解决方法,需要的朋友可以参考下
    2024-01-01
  • MySQL重置密码终极版(附详细步骤)

    MySQL重置密码终极版(附详细步骤)

    mysql是最常见的关系型数据库管理系统之一,它是开源的,易于使用和管理,对于mysql管理员来说,密码管理是非常重要的,因为数据库可能保存着重要的信息,这篇文章主要介绍了MySQL重置密码终极版的相关资料,需要的朋友可以参考下
    2025-07-07
  • 一文带你了解如何用MySQL通配符实现过滤功能

    一文带你了解如何用MySQL通配符实现过滤功能

    本文章将介绍什么是通配符、如何使用通配符以及怎样使用LIKE操作符进行通配搜索,以便对数据进行复杂过滤,感兴趣的小伙伴跟着小编一起来学习吧
    2023-07-07

最新评论