MySQL字符串排序实战:数字、百分比和文件名排序技巧
创作时间:
作者:
@小白创作中心
MySQL字符串排序实战:数字、百分比和文件名排序技巧
引用
CSDN
1.
https://blog.csdn.net/weixin_49114503/article/details/141053164
在数据库开发中,我们经常会遇到字符串类型存储了数字、百分比等数据的情况。如果直接使用varchar进行排序,往往无法得到预期的结果。本文将介绍如何在MySQL中对字符串进行数字排序、百分比排序以及从字符串中提取数字排序。
一、MySQL字符串按数字排序
假设我们有一张表test,其中number字段存储了数字字符串:
CREATE TABLE `test` (
`id` int NOT NULL PRIMARY KEY AUTO_INCREMENT comment '主键id',
`number` varchar(10) DEFAULT NULL COMMENT '数字'
);
insert into test(`number`) values
('89.01'),
('89.10'),
('100.01');
如果我们直接按照number字段进行排序:
select * from test order by `number` desc;
结果可能不符合预期:
这是因为字符串排序是按照字符的ASCII码进行的。为了解决这个问题,我们可以使用CAST或CONVERT函数将字符串转换为数字类型:
方法一:转换为浮点数
select * from test order by cast(number as float) desc;
select * from test order by convert(number, float) desc;
方法二:转换为双精度数
select * from test order by cast(number as double) desc;
select * from test order by convert(number, double) desc;
方法三:转换为十进制数
select * from test order by cast(number as decimal(10,2)) desc;
select * from test order by convert(number, decimal(10,2)) desc;
如果字段中全是整数无小数点,也可以使用下面的方式进行排序:
select * from test order by cast(number as SIGNED) desc;
select * from test order by convert(number, SIGNED) desc;
二、MySQL字符串百分比排序
假设我们有一张表test,其中percent字段存储了百分比字符串:
CREATE TABLE `test` (
`id` int NOT NULL PRIMARY KEY AUTO_INCREMENT comment '主键id',
`percent` varchar(10) DEFAULT NULL COMMENT '百分比'
);
insert into test(percent) values
('89.01%'),
('89.10%'),
('100.01%');
我们可以使用以下方法进行排序:
方法一:直接转换为十进制数
select * from test order by cast(percent as decimal(10,2)) desc;
select * from test order by convert(percent , decimal(10,2)) desc;
方法二:先移除百分号再转换
select * from test order by cast(REPLACE(percent, '%', '') as decimal(10,2)) desc;
select * from test order by convert(REPLACE(percent, '%', '') , decimal(10,2)) desc;
三、从字符串中提取数字并排序
假设我们有一张表test1,其中file_name字段存储了文件名:
CREATE TABLE `test1` (
`id` int NOT NULL PRIMARY KEY AUTO_INCREMENT comment '主键id',
`file_name` varchar(10) DEFAULT NULL COMMENT '文件名'
);
insert into test1(file_name) values
('中文_1.txt'),
('中文_2.txt'),
('中文_10.txt'),
('中文_12.txt');
我们可以使用REGEXP_SUBSTR函数提取数字部分并排序:
SELECT *
FROM test1
WHERE file_name LIKE '%中文%'
ORDER BY CAST(REGEXP_SUBSTR(file_name , '\\d+') AS UNSIGNED);
这条SQL语句做了以下几件事:
WHERE original_name LIKE '%中文%':筛选出所有文件名包含“中文”的记录。REGEXP_SUBSTR(original_name, '\\d+'):从 original_name 中提取第一组连续的数字。CAST(... AS UNSIGNED):将提取出的字符串转换成无符号整数,以便按数字进行排序。
排序结果如下:
热门推荐
2024年中国高职专科院校排名:校友会与金平果权威榜单全解析
剧本写作基础:三幕结构详解
崇祯元年五月,袁崇焕的命运就此决定
金融资产处置损益是什么
盘点常见春季树花粉过敏原
教会狗狗认知人类:宠物界的沟通秘籍!
蓝莓对近视眼真的有用吗
吴冠中:艺术诞生于艺术家的孤独,谁也不能例外
全面解读:TOPCon技术的底层优势与未来形态
乐至特色美食:从七芯莲藕到坛子肉
女子模仿哪吒穿衣火了,粉红色肚兜演的好,眼睛直接挪不开
2024龙年美食家速成指南:怎么描写东西好吃,写出让人垂涎欲滴的文字!
肌无力患者的日常饮食指南
什么是垂直同步?不同使用场景下的最佳选择
在更新后管理设备重启
坐拥3亿信众,妈祖是下一个出海“神话”?
睡眠专家:快速入睡的3个妙招
判断自己是否为公网ip,设置端口映射,以及利用公网ip搭建网站服务测试
人工智能的五大特性:智能性、学习性、自主性、适应性和泛化性
流量传感器的工作原理及分类
最高法民一庭关于建设工程施工合同纠纷专业法官会议纪要(更新版)
香港银行存款利率真相:高息存款多为短期促销
朝鲜神秘的柳京饭店,建成30多年却不开张,背后隐藏着什么秘密
快手早餐~米酒汤圆
一个广西民宿老板的十年:打工还债,苦乐自当
如何做好团队工作汇报稿
如何确保APP的合规性与安全性?——深入探讨APP合规性及安全性测试
甲状腺结节:何时手术?术后护理全攻略!
法院执行的案件如何再审
遭遇“烂尾楼”,该怎么办?