mysql实现将字符串字段转为数字排序或比大小
mysql里面有个坑就是,有时按照某个字段的大小排序(或是比大小)发现排序有点错乱。后来才发现,是我们想当然地把对字符串字段当成数字并按照其大小排序(或是比大小),结果肯定不会是你想要的结果。
这时候需要把字符串转成数字再排序。
最简单的办法就是在字段后面加上+0
方法一:
ORDER BY '123'+0;(首推)
方法二:
ORDER BY CAST('123' AS SIGNED);
方法三:
ORDER BY CONVERT('123',SIGNED);