Mysql查询用某一列数字来进行降序排序,排序不准确,数值小的排在了数值大的前面

本文记录了一次在数据库查询中遇到的排序问题,详细解释了为何VARCHAR类型字段会导致排序错误,尤其是在数字排序时,'9'>'10'的情况。通过调整字段类型为数值类型或使用+0转换,成功解决了排序问题。

今天在查询数据进行排序的时候,发现了一个小问题,那就是排序出来的顺序是不正确的。在这做一个记录
语句是这样的SELECT * FROMtestORDER BYtimedesc ;
结果排序是不对的最后经过

show create table test;

查询出来,发现它的类型是varchar,并不是数值类型。

在这里插入图片描述

这也就知道原因了,这是因为你的字段类型是文本类型,而在文本类型里面,‘9’>‘10’,文本类型下是从左边开始比较的
而只需要把字段修改为数值类型,或者查询的是使用使用+0转换为数值,即可进行正常排序了
而我选择了后者

SELECT * FROM `test`  ORDER BY `time`+0 desc ;

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值