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的联合索引(复合索引)的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • Mysql 本地计算机无法启动 mysql 服务 错误 1067:进程意外终止。

    Mysql 本地计算机无法启动 mysql 服务 错误 1067:进程意外终止。

    初学php接触mysql,遇到一些问题,卸载重装后,无法启动mysql服务,网络上有很多种说法,我这里将我解决这个问题的办法提出
    2009-12-12
  • mysql 截取指定的两个字符串之间的内容

    mysql 截取指定的两个字符串之间的内容

    今天我同事在用mysql的时候,需要对一个字符串中的指定内容进行截取
    2009-07-07
  • MySQL transaction事务安全示例讲解

    MySQL transaction事务安全示例讲解

    这篇文章主要为大家介绍了MySQL数据库事务安全transaction的示例讲解教程,事务就是将一组操作封装成一个执行单元,要么一块执行成功,要么一块失败,不存在部分执行成功的情况。事务保证了执行的稳定性,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2022-06-06
  • mysql中find_in_set()函数用法及自定义增强函数

    mysql中find_in_set()函数用法及自定义增强函数

    MySQL 中的 FIND_IN_SET 函数用于在逗号分隔的字符串列表中查找指定字符串的位置,本文就来介绍一下mysql中find_in_set()函数用法及自定义增强函数
    2024-08-08
  • mysql视图原理与用法实例详解

    mysql视图原理与用法实例详解

    这篇文章主要介绍了mysql视图原理与用法,结合实例形式详细分析了mysql视图的概念、原理、使用方法及操作注意事项,需要的朋友可以参考下
    2020-04-04
  • MySQL8.0.21安装步骤及出现问题解决方案

    MySQL8.0.21安装步骤及出现问题解决方案

    这篇文章主要介绍了MySQL8.0.21安装步骤及出现问题解决方案,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • MySQL中列如何以逗号分隔转成多行

    MySQL中列如何以逗号分隔转成多行

    这篇文章主要介绍了MySQL中列如何以逗号分隔转成多行问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • MySQL中distinct语句去查询重复记录及相关的性能讨论

    MySQL中distinct语句去查询重复记录及相关的性能讨论

    这篇文章主要介绍了MySQL中distinct语句去查询重复记录及相关的性能讨论,文中的观点是在一定情况下避免在最高层查询中使用distinct,需要的朋友可以参考下
    2016-01-01
  • 详解MySQL中的事务与ACID特性

    详解MySQL中的事务与ACID特性

    这篇文章主要为大家介绍了Mysql 中的事务,包括事务的基本概念和 ACID 特性、事务的隔离级别和具体实现方法等,并提供相应的代码示例,希望对大家有所帮助
    2023-05-05

最新评论