在MySQL中按字符串中的数字排序的详细教程

 更新时间:2024年07月02日 09:55:00   作者:一勺菠萝丶  
本文将详细介绍如何在MySQL中利用正则表达式提取字符串中的数字并按这些数字进行排序,以一个具体的例子来说明,使得即使是数据库操作的初学者也能轻松理解和应用,需要的朋友可以参考下

在管理数据库时,我们经常遇到需要按嵌入在字符串中的数字进行排序的情况。这在实际应用中尤为常见,比如文件名、代码版本号等字段中通常包含数字,而这些数字往往是排序的关键。本文将详细介绍如何在MySQL中利用正则表达式提取字符串中的数字并按这些数字进行排序,以一个具体的例子来说明,使得即使是数据库操作的初学者也能轻松理解和应用。

场景示例

假设你管理的数据库中有一个表 sys_oss,它记录了多媒体文件的信息。表中有一个字段 original_name,其中包含了文件的命名信息,格式大致为“中文_数字.mp4”。现在,我们的任务是按照文件名中的数字顺序对这些记录进行排序。

示例数据

让我们先看几个 original_name 的示例值:

  • 中文_1.mp4
  • 中文_12.mp4
  • 中文_2.mp4
  • 中文_10.mp4

如果按照字符串默认的排序方式,排序结果将会是:

  • 中文_1.mp4
  • 中文_10.mp4
  • 中文_12.mp4
  • 中文_2.mp4

在这里插入图片描述

这显然不符合数字自然排序的逻辑,因为字符串排序是按字符编码顺序逐一比较的。我们的目标是按照数字部分的实际数值进行排序,即:

  • 中文_1.mp4
  • 中文_2.mp4
  • 中文_10.mp4
  • 中文_12.mp4

在这里插入图片描述

使用 REGEXP_SUBSTR 函数提取并排序

在MySQL 8.0及以上版本中,我们可以使用 REGEXP_SUBSTR() 函数来提取字符串中的数字部分。这个函数允许我们使用正则表达式来指定我们想要匹配的模式。在这个例子中,我们使用正则表达式 \\d+ 来匹配一个或多个数字。

以下是完整的SQL查询,用于实现按数字排序:

SELECT *
FROM sys_oss
WHERE original_name LIKE '%中文%'
ORDER BY CAST(REGEXP_SUBSTR(original_name, '\\d+') AS UNSIGNED);

这条SQL语句做了以下几件事:

  • WHERE original_name LIKE '%中文%':筛选出所有文件名包含“中文”的记录。
  • REGEXP_SUBSTR(original_name, '\\d+'):从 original_name 中提取第一组连续的数字。
  • CAST(... AS UNSIGNED):将提取出的字符串转换成无符号整数,以便按数字进行排序。

结论

使用 REGEXP_SUBSTR 提取数字并结合 CAST 函数转换类型,使我们能够按照数字的实际数值对字符串进行排序。这种技巧不仅适用于文件名,也可以广泛应用于任何包含数字的字符串字段排序,如订单编号、版本号等

以上就是在MySQL中按字符串中的数字排序的详细教程的详细内容,更多关于MySQL按字符串的数字排序的资料请关注脚本之家其它相关文章!

相关文章

  • mysql中如何对列求和

    mysql中如何对列求和

    这篇文章主要介绍了mysql中如何对列求和问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • MySQL必备基础之分组函数 聚合函数 分组查询详解

    MySQL必备基础之分组函数 聚合函数 分组查询详解

    这篇文章主要介绍了MySQL分组函数、聚合函数、分组查询,结合实例形式分析了MySQL查询分组函数以及查询聚合函数相关使用技巧,需要的朋友可以参考下
    2021-10-10
  • 一篇文章带你掌握MySQL索引下推

    一篇文章带你掌握MySQL索引下推

    索引条件下推,也叫索引下推,英文全称Index Condition Pushdown,简称ICP,索引下推是MySQL5.6新添加的特性,用于优化数据的查询,下面这篇文章主要给大家介绍了关于MySQL索引下推的相关资料,需要的朋友可以参考下
    2022-12-12
  • Mariadb远程登陆配置及问题解决

    Mariadb远程登陆配置及问题解决

    这篇文章主要介绍了Mariadb远程登陆配置及问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-08-08
  • 基于mysql查询语句的使用详解

    基于mysql查询语句的使用详解

    本篇文章是对mysql查询语句的使用进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • MYSQL多表联查on和where的区别小结

    MYSQL多表联查on和where的区别小结

    在使用left join时过滤条件放到on后面还是where后面是有区别的,如果没有搞清楚他们的区别,连表汇总的结果就会变少或者变多,本文就来详细介绍一下两者的区别,感兴趣的可以了解一下
    2023-11-11
  • ‌MySQL中‌between and的基本用法‌操作方法

    ‌MySQL中‌between and的基本用法‌操作方法

    本文主要介绍了MySQL中BETWEEN AND操作符的基本用法,包括数值查询和时间范围查询,同时还详细解释了NOT BETWEEN AND的使用方法,并通过实例进行了详细的演示,其中,BETWEEN AND可以用于数值、日期等类型的字段,包括边界值
    2024-10-10
  • MySQL server has gone away 问题的解决方法

    MySQL server has gone away 问题的解决方法

    MySQL server has gone away 问题解决方法,需要的朋友可以参考下。
    2010-06-06
  • Mysql保持现有内容在后面增加内容的sql语句

    Mysql保持现有内容在后面增加内容的sql语句

    这篇文章主要介绍了Mysql保持现有内容在后面增加内容的sql语句,需要的朋友可以参考下
    2017-05-05
  • mysql同步复制搭建方法指南详细步骤

    mysql同步复制搭建方法指南详细步骤

    MySQL数据同步主要有三种方式: 1.利用MySQL自身的数据库同步功能 2.利用MySQL数据库的特性(数据库存在固顶目录,并且以文件形式存储),进行数据库目录同步以达到数据同步目的 3.利用专用的MySQL数据库同步软件
    2008-04-04

最新评论