MySQL之解决字符串数字的排序失效问题

 更新时间:2023年08月26日 10:51:00   作者:一碗谦谦粉  
这篇文章主要介绍了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死锁使用详解及检测和避免方法

    这篇文章主要介绍了MySQL死锁使用详解及检测和避免方法,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-07-07
  • SQL查询执行顺序分析

    SQL查询执行顺序分析

    这篇文章主要为大家介绍了SQL查询执行顺序分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • 防止服务器宕机时MySQL数据丢失的几种方案

    防止服务器宕机时MySQL数据丢失的几种方案

    这篇文章主要介绍了防止服务器宕机时MySQL数据丢失的几种方案,结合实践介绍了Replication和Monitor以及Failover这三个项目的应用,需要的朋友可以参考下
    2015-06-06
  • MySQL 5.0触发器参考教程

    MySQL 5.0触发器参考教程

    需要学习mysql触发器的朋友需要了解的东西,整理的比较多,建议大家慢慢多练习
    2008-09-09
  • mysql报错sql_mode=only_full_group_by解决

    mysql报错sql_mode=only_full_group_by解决

    这篇文章主要为大家介绍了mysql报错sql_mode=only_full_group_by解决,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08
  • MySQL replace into 语句浅析(二)

    MySQL replace into 语句浅析(二)

    这篇文章主要介绍了MySQL replace into 语句浅析(二),本文着重给出了几个特殊案例分析,需要的朋友可以参考下
    2015-05-05
  • MySQLMerge存储引擎

    MySQLMerge存储引擎

    MERGE存储引擎把一组MyISAM数据表当做一个逻辑单元来对待,让我们可以同时对他们进行查询。本文给大家介绍MySQLMerge存储引擎,需要的朋友参考下吧
    2016-03-03
  • 关于Mysql中文乱码问题该如何解决(乱码问题完美解决方案)

    关于Mysql中文乱码问题该如何解决(乱码问题完美解决方案)

    这篇文章给大家介绍关于Mysql中文乱码问题该如何解决(乱码问题完美解决方案)的相关资料,还给大家收集些关于MySQL会出现中文乱码原因常见的几点,小伙伴快来看看吧
    2015-11-11
  • mysql 5.7.23 安装配置方法图文教程

    mysql 5.7.23 安装配置方法图文教程

    这篇文章主要为大家详细介绍了mysql 5.7.23安装配置方法图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-09-09
  • MySQL存储函数以及触发器详解

    MySQL存储函数以及触发器详解

    这篇文章详细给大家介绍了MySQL-SQL存储函数以及触发器,文中有详细的代码示例,对我们学习MySQL有一定的帮助,感兴趣的朋友可以参考阅读下
    2023-06-06

最新评论