码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 解决MySQL需要根据特定顺序排序


    文章目录

    • 0 写在前面
    • 1 问题引入
    • 2 问题解决
    • 3 写在末尾

    0 写在前面

    在进行业务需求的时候,不会根据排序去选择数据。例如,在导出的时候数据排序是根据编辑时间去排序的,那么他的主键id会打乱。
    假如: 要导出id为 3 ,1 , 2 ,6 , 5 的数据并且根据此顺序导出。

    1 问题引入

    如果直接在MySQL中写

    SELECT 数据
    FROM 表名
    WHERE 表名id IN (3, 1, 2, 6, 5)
    
    • 1
    • 2
    • 3

    会发生MYSQL默认排序规则;
    在这里插入图片描述

    2 问题解决

    使用mysql的FIELD()函数进行自定义排序
    使用id为例:

    SELECT 数据
    FROM 表名
    WHERE 表名.id IN (所有id)
    order by FIELD(id, 排序规则);
    
    • 1
    • 2
    • 3
    • 4

    在这里插入图片描述
    注意:排序规则需要一一对应,即使在 in()的数据不影响,只要在field()确认规则即可
    在这里插入图片描述

    3 写在末尾

    因为从业务里传过来的数据肯定是规则排序,所以建议用IN() 和 FIELD()里的排序 对应起来是最保险的。

  • 相关阅读:
    迅雷下载宝-openwrt-kodexplorer
    (c语言)位操作符
    一文1500字手把手教你Jmeter如何压测数据库【保姆级教程】
    SpringBoot与Shiro整合(认证、授权和密码加密)
    电脑扬声器未插入?4个方法帮你恢复声音!
    PCIE
    kali没有wlan0
    【智能优化算法】基于沙猫群优化算法求解单目标优化问题附matlab代码
    一个UI设计师自学编程的经历
    李廉洋:4.24黄金看跌趋势明显,原油今日或呈震荡走势分析及策略。
  • 原文地址:https://blog.csdn.net/weixin_45909221/article/details/134284091
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号