• MybatisPlus 中MySQL排序失效问题的解决


    作为一个CRUD 工程师,今天在写sql得时候,出现一个问题,按照一个decimal字段排序的时候,并没有按照要求进行排序,开始误认为是mysql问题,以为没有按照浮点类型进行排序,我就一顿操作猛如虎,将数据进行转换:
    sql 如下:

    	select a_stk_pct_chg1 from land_hk_north_stat  order by 'a_stk_pct_chg1' desc 
    
    • 1

    错误观点

    误认为这个字段是varchar类型。不能直接排序,
    解决方案
    在不修改原有设计的情况下,只能改SQL了,我们需要先把字符串转数字。

    1、将varchar类型 +0操作,类似java得强转

    order by (a_stk_pct_chg1+0) desc
    
    • 1

    2、用函数CAST(value as type)或CONVERT(value, type)

    type可为DECIMAL (浮点数 )、SIGNED(整数)、UNSIGNED (无符号整数 )

    order by CAST(a_stk_pct_chg1 as DECIMAL) desc
    
    • 1

    或者

    order by CONVERT(a_stk_pct_chg1,DECIMAL) desc
    
    • 1

    但是!!!以上方法都用了一遍,真是鸟用都没有,我心头顿感一凉,这算是芭比Q了,但是作为合格程序猿必须得不抛弃不抛弃,经过我仔细查阅资料,在sql日志中找到端倪,原来是MybatisPlus 变量定义转义得问题!

    来先上xml中部分sql

    	
    			ORDER BY  ${params.sortFild} DESC
    		
    
    • 1
    • 2
    • 3

    1、对于形如#{sortFild}的变量,Mybatis会将其视为字符串值,在变量替换成功后,缺省地给变量值加上引号
    得到结果就是

    ORDER BY ‘sortFild' DESC
    
    • 1

    2、对于形如${sortFild}的变量,Mybatis会将其视作直接变量,即在变量替换成功后,不会再给其加上引号。

     ORDER BY  sortFild  DESC
    
    • 1

    然后运行一下服务,问题完美解决~


    关注我的微信公众号
    ​​​​在这里插入图片描述

  • 相关阅读:
    数字逻辑·数制转换、编码方法
    springboot医疗管理系统毕业设计源码015221
    DDOS攻击防御介绍
    Java测试(12)---性能测试
    第五章 树 6 AcWing 1576. 再次树遍历
    vue中倒计时(日,时,分,秒)的计算和当前时间计时读秒
    使用Mapster实现双向映射,解放搬砖体力活
    Cocos creator 学习笔记(2)
    Apache Linkis参数介绍
    Python 基础合集1:基本数据类型
  • 原文地址:https://blog.csdn.net/CharlesYooSky/article/details/126138610