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

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

	select a_stk_pct_chg1 from land_hk_north_stat  order by 'a_stk_pct_chg1' desc 
错误观点

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

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

order by (a_stk_pct_chg1+0) desc

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

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

order by CAST(a_stk_pct_chg1 as DECIMAL) desc

或者

order by CONVERT(a_stk_pct_chg1,DECIMAL) desc

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

来先上xml中部分sql

	<if test="params.sortFild != null ">
			ORDER BY  ${params.sortFild} DESC
		</if>

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

ORDER BY ‘sortFild' DESC

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

 ORDER BY  sortFild  DESC

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


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

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MybatisPlus的last()方法是用于手动将SQL语句拼接到最后的方法。它可以将指定的字符串直接拼接到SQL语句的最后,但需要注意的是,使用last()方法存在SQL注入的风险,因此需要谨慎使用。\[1\] 在具体的业务功能,可以根据需要灵活运用last()方法。然而,需要注意的是,last()方法会无视优化规则,直接将字符串拼接到SQL的最后,可能需要考虑一些因素。例如,在最开始的书写方式,可以使用.last()方法将条件拼接到SQL语句的最后,如示例代码的.where("a.staff_id = b.staff_id and a.archive_date = b.archive_date GROUP BY a.staff_id")。\[2\] 通常情况下,last()方法与limit一起使用的概率较大。可以通过QueryWrapper对象的last()方法来指定limit的值,如示例代码的.last("limit 1,10")。这样可以限制查询结果的数量,只返回指定范围内的数据。\[3\] #### 引用[.reference_title] - *1* [MyBatisPlus条件构造器last方法怎样使用](https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/89503209)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [mybatisplus last()](https://blog.csdn.net/weixin_46505978/article/details/128369574)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值