MySQL之解决字符串数字的排序失效问题
MySQL字符串数字的排序失效问题
问题描述
最近在做老项目维护时,有客户反映说,视图的序号排序有问题。
这里的序号,相当于是排序号,由用户自定义输入排序号,来自定义某些数据的前后位置。

但是检查了一下SQL,又是没有问题的。
"select * from contractFil where istmp=0 order by sort desc";
后来,查看表设计,发现列sort是varchar类型的。
所以不能直接排序。
解决
在不修改原有设计的情况下,只能改SQL了,我们需要先把字符串转数字。
字符串转数字的三种方式:
(1)+0
order by (sort+0) desc
(2)用函数CAST(value as type)或CONVERT(value, type)
type可为DECIMAL (浮点数 )、SIGNED(整数)、UNSIGNED (无符号整数 )
order by CAST(sort as SIGNED) desc order by CONVERT(sort ,SIGNED)desc
MySQL中ORDER BY排序错误
记录一个错误
这是使用format函数来进行小数点后两位保留,使用这个会导致排序错误。
SELECT enterprise_key_id, enterprise_name_cn, occupied_area, registered_place_key_id, registered_place_name, registered_capital, registered_capital_type_key_id, registered_capital_type_name, -- ROUND(sum( IFNULL( tax_aa, 0 ) ) / 10000,2) AS last_year_taxtotal FORMAT( IFNULL( sum( IFNULL( tax_aa, 0 ) ) / 10000, 0 ), 2 ) AS last_year_taxtotal FROM etl_enterprise_base_info WHERE archived_year_month LIKE CONCAT( '%', YEAR ( DATE_SUB( NOW( ), INTERVAL 1 YEAR ) ), '%' ) AND registered_place_key_id = 8 GROUP BY enterprise_key_id ORDER BY last_year_taxtotal DESC

使用ROUND函数来进行排序就没有出错。

总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Mysql 本地计算机无法启动 mysql 服务 错误 1067:进程意外终止。
初学php接触mysql,遇到一些问题,卸载重装后,无法启动mysql服务,网络上有很多种说法,我这里将我解决这个问题的办法提出2009-12-12
mysql中find_in_set()函数用法及自定义增强函数
MySQL 中的 FIND_IN_SET 函数用于在逗号分隔的字符串列表中查找指定字符串的位置,本文就来介绍一下mysql中find_in_set()函数用法及自定义增强函数2024-08-08
MySQL中distinct语句去查询重复记录及相关的性能讨论
这篇文章主要介绍了MySQL中distinct语句去查询重复记录及相关的性能讨论,文中的观点是在一定情况下避免在最高层查询中使用distinct,需要的朋友可以参考下2016-01-01


最新评论