今天在查询数据进行排序的时候,发现了一个小问题,那就是排序出来的顺序是不正确的。在这做一个记录
语句是这样的SELECT * FROM
testORDER BY
timedesc ;
结果排序是不对的最后经过
show create table test;
查询出来,发现它的类型是varchar,并不是数值类型。
这也就知道原因了,这是因为你的字段类型是文本类型,而在文本类型里面,‘9’>‘10’,文本类型下是从左边开始比较的
而只需要把字段修改为数值类型,或者查询的是使用使用+0转换为数值,即可进行正常排序了
而我选择了后者
SELECT * FROM `test` ORDER BY `time`+0 desc ;