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

网友投稿 1457 2022-11-10

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

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

ORDER BY ${params.sortFild} DESC

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

ORDER BY ‘sortFild' DESC

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

ORDER BY sortFild DESC

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

​​​

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:MacOS上交叉编译cgo项目到Linux
下一篇:第十二章 使用中的 OpenAPI 属性
相关文章

 发表评论

暂时没有评论,来抢沙发吧~