Mysql自定义顺序查询

1、使用函数

        MySQL 的 ORDER BY FIELD() 函数可以按照指定的自定义顺序对查询结果进行排序,而不是默认的升序(ASC)或降序(DESC)。

2、适用场景

        后端/运营人员经常需要临时把某几条记录‘拽’到最前(或最后)显示,而业务表里又没有现成的排序字段或枚举值。

场景类别说明示例
后台列表“置顶/置底”运营在后台商品、订单、文章列表里勾选“把这几条排在最前”。代码里只需把勾选的 id 塞进 FIELD(),无需改表结构。ORDER BY FIELD(id, 5, 9, 12)
枚举值按业务含义排序状态、类型等枚举值在界面要按非字母顺序显示(如“审核中→通过→驳回”)。ORDER BY FIELD(status,'checking','passed','rejected')
临时活动或灰度白名单做 A/B 实验或灰度发布时,把指定用户/商品优先曝光,名单可能天天变,不想频繁改表。ORDER BY FIELD(user_id, 10001, 10087, 10233)
报表/导出文件固定行列顺序财务或数据组导出 Excel 时,要求列顺序固定(如“北京、上海、深圳、其他”)。ORDER BY FIELD(city,'北京','上海','深圳')

不适合的场景

  • 排序规则长期稳定 → 应该直接在表里加 sort 字段并建索引,性能更好。

  • 数据量大且需要分页 → FIELD() 无法走索引,深分页会变慢;可改为冗余排序列或 ORDER BY CASE … WHEN … THEN 1 WHEN … THEN 2 END

3、基本语法

SELECT 列名
FROM 表名
ORDER BY FIELD(排序字段, 值1, 值2, 值3, ...);

4、示例

        按指定状态顺序排序。假设有一个 orders 表,包含订单状态 status 字段,可能的值为 'pending'(待处理)、'processing'(处理中)、'shipped'(已发货)、'delivered'(已送达)。如果想按照 'processing' → 'pending' → 'shipped' → 'delivered' 的自定义顺序排序:

SELECT id, status, order_date
FROM orders
ORDER BY FIELD(status, 'processing', 'pending', 'shipped', 'delivered');

表结构和数据

--
-- Table structure for table `orders`
--DROP TABLE IF EXISTS `orders`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!50503 SET character_set_client = utf8mb4 */;
CREATE TABLE `orders` (`id` bigint NOT NULL AUTO_INCREMENT,`status` varchar(100) NOT NULL COMMENT '订单状态',`order_date` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
/*!40101 SET character_set_client = @saved_cs_client */;--
-- Dumping data for table `orders`
--LOCK TABLES `orders` WRITE;
/*!40000 ALTER TABLE `orders` DISABLE KEYS */;
INSERT INTO `orders` VALUES (1,'processing','2025-08-07 17:19:16'),(2,'pending','2025-08-07 17:19:16'),(3,'shipped','2025-08-07 17:19:16'),(4,'delivered','2025-08-07 17:19:16'),(5,'shipped','2025-08-07 17:19:16'),(6,'pending','2025-08-07 17:19:16'),(7,'processing','2025-08-07 17:19:16'),(8,'shipped','2025-08-07 17:19:16'),(9,'pending','2025-08-07 17:19:16'),(10,'delivered','2025-08-07 17:19:16');
/*!40000 ALTER TABLE `orders` ENABLE KEYS */;
UNLOCK TABLES;
/*!40103 SET TIME_ZONE=@OLD_TIME_ZONE */;

查询结果

5、注意事项

  • 性能FIELD() 无法利用索引,大数据量时可能较慢,可考虑 ORDER BY CASE 或冗余排序列加索引。
  • NULL 处理FIELD() 中若列值为 NULL,会返回 0,排序行为与不在列表中的值相同。
  • FIELD() 函数是大小写敏感的(取决于数据库的 collation 设置)。
  • 如果指定的值在排序字段中不存在,这些值会被忽略,不影响排序。
  • 不在指定列表中的值会被排在所有指定值的后面。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/918013.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/918013.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

回归预测 | MATLAB实现RBF径向基神经网络多输入单输出回归预测+SHAP可解释分析

目录 基于RBF径向基神经网络多输入单输出回归预测及SHAP可解释分析的研究 摘要 1. 引言 1.1 研究背景 1.2 研究意义 1.3 研究目标与内容 2. 文献综述 2.1 RBF径向基神经网络研究现状 2.2 SHAP可解释分析研究进展 3. RBF径向基神经网络原理 4. SHAP可解释分析理论基础 4.1 Shapl…

--- Eureka 服务注册发现 ---

Euraka 是netfix开发的基于REST服务基于AP框架的注册中心,主要是用于服务的注册,管理,负载均衡,服务故障转移 Eureka主要分俩部分Eureka Server:服务中心Server端,提供服务注册 发现 健康检查等服务Eureka …

vue3 el-select 加载内容后 触发事件

在 Vue 3 中使用 Element UI 的 el-select 组件实现加载内容后触发事件,主要有以下两种常见需求及实现方式:加载数据后触发事件若需在数据加载完成后触发特定事件(如页面渲染完成),可通过自定义指令监听滚动容器状态&a…

c# winform 调用 海康威视工业相机(又全又细又简洁)

1.准备一个海康相机 从垃圾桶里翻出来一个USB口相机。 2.下载MVS 和SDK 海康机器人-机器视觉-下载中心 mvs: sdk: 用MVS 调试一下,能连接就行。 海康威视相机,MVS连接成功,但无图像怎么办?-CSDN博客 3.打…

前端页面直接生成PDF下载文件

前言 因为要实现业务需求如下图,业务逻辑,该凭证为前端代码实现,为了简单方便实现下载为pdf的需求。 一、怎么在前端直接生成PDF? 需求描述:浏览器打开的这个页面,点击下载,把当前弹框页面的…

性能优化——GPU的影响

关闭MSAA 之前在查一个渲染问题,一开始是定位到了CPU在waitforFrame所以知道是GPU的问题但如何定义GPU的问题在哪里,就很麻烦。我一开始以为是drawcall的问题,因为我发现drawcall有350个但降低到30个后,依然情况没有好转。毕竟dra…

软件需求关闭前的质量评估标准是什么

在 需求关闭前,进行 质量评估 是确保需求被完整实现、测试充分且满足业务目标的关键步骤。以下是需求关闭前的质量评估标准,涵盖了功能、非功能、测试覆盖率和用户满意度等方面:一、功能实现的质量评估标准需求完整性:所有功能需求…

vscode中创建python虚拟环境的方法

文章目录框架不同python解释器vscode运行python需要的插件vscode可以改变执行python脚本的默认终端虚拟环境解释创建虚拟环境的方法python的settings.json的一些好用配置框架 python解释器->虚拟环境->vscode 不同python解释器 在一台电脑中我们可以安装多个版本的pyt…

基于 ShardingSphere 的 Spring Boot 数据加密与模糊查询实现

基于 ShardingSphere 的 Spring Boot 数据加密与模糊查询实现 在数据安全与查询便捷性并重的今天,敏感数据加密存储后如何支持灵活查询成为关键挑战。本文将聚焦ShardingSphere 在实现数据加密的同时支持模糊查询的核心能力,详细介绍基于 Spring Boot 和 ShardingSphere 的完…

计算虚拟化技术

🧠 一、什么是计算虚拟化?(基础认识) ✅ 基本概念: 计算虚拟化(Compute Virtualization) 是指:在一台物理服务器上模拟多个“虚拟计算资源”,每个虚拟机看起来像是一台独…

Python编程基础与实践:Python基础数据结构:列表、字典和集合

Python数据结构:掌握列表、字典和集合 学习目标 通过本课程的学习,学员将掌握Python中基本的数据结构:列表、字典和集合。学员将了解它们的特性、使用场景以及如何高效地使用它们来解决实际问题。 相关知识点 列表、字典和集合使用 学习…

三维偏序 -- cdq 套 cdq

似乎题解区并没有 cdq 套 cdq 的作法,刚好今天讲了,就来写一发。 题意与记号 题目讲的很清楚了。此方法并没有树状数组好想也没有其高效,但能很方便扩展。下文记原序列为 ddd,将每个点拆分成点与询问,内部增加一个名为…

Effective C++ 条款27: 尽量用const、enum、inline替换 #define

Effective C 条款27:尽量用const、enum、inline替换#define核心思想:使用编译器(const, enum, inline)替代预处理器(#define),让编译器进行语义检查,避免宏替换引发的错误和调试困难…

芯谷科技--高效噪声降低解决方案压缩扩展器D5015

在无绳电话系统中,噪声降低是提升通话质量的关键。 D5015 压缩扩展器,通过集成压缩器和扩展器,有效降低了传输噪声,同时保持了信号的完整性。D5015 采用 SOP20 和 DIP20 封装形式,具有低电压工作、低功耗、高集成度等特…

LabVIEW车床静刚度自动测

​基于LabVIEW 平台开发车床静刚度自动测试系统,针对传统生产法测量中人工误差大、计算复杂、效率低等问题,结合误差复映规律与刚度方程,通过高精度硬件与软件协同,实现试件加工前后尺寸的在线采集、自动计算与报告生成&#xff0…

汽车流通行业4S门店生存性指标:零服吸收率

我们在做汽车4S集团的商业智能BI数据分析项目中,对于4S店的管理,大家经常会提到一个分析指标,叫“零服吸收率”,这个大概是什么意思呢?简单来说就是4S门店一台车都没有卖出的情况下,光靠售后服务部分的收益…

第一性原理科学计算服务器如何选择配置-CPU选择篇

一、 大多数人知道的 (显性因素)核心数与线程数 (Core Count & Thread Count): 重要性: 核心是王道。 科学计算任务(如仿真、建模、数据分析、机器学习训练)绝大多数都高度并行化,可以同时利用多个核心进行计算。选择建议&…

Java 后端 + JavaScript 前端 实现按钮级别权限控制的解决方案

Java JavaScript 前后端协同实现按钮权限控制 在后台管理系统中,不同用户根据角色和数据状态应展示不同的操作按钮,比如编辑、删除、审批、提交等操作。本文将介绍一种通过 Java 后端生成按钮权限 JSON,前端通过 jQuery 解析控制按钮显示的…

RAG面试内容整理-18. 向量量化与索引压缩技术(PQ, HNSW 等)

当知识库规模达到百万甚至数亿级文档时,向量索引的存储和查询效率成为关键瓶颈。向量量化是一类用较低比特表示近似向量的方法,大幅压缩内存占用并加速相似度计算。PQ(Product Quantization)是其中最著名的方法之一,被Faiss等库广泛实现。PQ的思想是将高维向量划分为多个子…

如何显示一个 Elasticsearch 索引的字段

作者:来自 Elastic JD Armada 学习如何使用 _mapping 和 _search API、子字段、合成 _source 和运行时字段来显示 Elasticsearch 索引的字段。 更多阅读: Elasticsearch:从搜索中获取选定的字段 fields Elasticsearch:inverted …