Mybatis order by 动态传参出现的问题及解决方法

作者:三分恶 时间:2022-07-26 04:13:09 

问题由来

一个简单的需求,要求把和当前用户相关的数据置顶展示。

这里,我用了一个简单的用户表来复现这个需求。

Mybatis order by 动态传参出现的问题及解决方法

很简单,查询语句后面加上:order by t.login_name='wulaoer' desc 就行了。

如下所示,吴老二就到顶了。

Mybatis order by 动态传参出现的问题及解决方法

那Mybatis脚本怎么写呢?

就这么写👇🏻


<select id="selectUserPageOrder" resultType="cn.fighter3.entity.User">
       select * from user t
       order by t.login_name=#{req.currentUser} desc
   </select>

OK,需求完成,测试,摸……

嗯,出bug了……

问题现场

定晴一看控制台,报错了。

Mybatis order by 动态传参出现的问题及解决方法

最关键的一行:

java.sql.SQLException: Parameter index out of range (1 > number of parameters, which is 0).

问题分析

问题很简单,随手一查,原因是:

#{}传过来的参数带单引号

#{}采用预编译机制,是占位符,#{}传入参数是以字符串传入,会将SQL中的#{}替换为?号,调用PreparedStatement的set方法来赋值。

这种方式,order by 最后的sql会多加单引号 ' 。

那怎么解决呢?

可以用 ${}${}是拼接符,直接字符串替换。


<select id="selectUserPageOrder" resultType="cn.fighter3.entity.User">
       select * from user t
       order by t.login_name=${req.currentUser} desc
   </select>

我不想用${}这种方式,因为有sql注入的风险,那该怎么办呢?

好吧,其实主要是这种方式也报错了😓。

java.sql.SQLSyntaxErrorException: Unknown column 'wulaoer' in 'order clause'

我们平时模糊查询怎么写呢?

——使用CONCAT()函数来拼接keyword。

以此类推,那我用一个函数来去掉'不就行了。

那用一个什么函数呢?

——REPLACE

所以写法就变成了这样:


<select id="selectUserPageOrder" resultType="cn.fighter3.entity.User">
       select * from user t
       order by t.login_name=REPLACE(#{req.currentUser},'\'','') desc
   </select>

问题解决

OK,最终问题解决。


<select id="selectUserPageOrder" resultType="cn.fighter3.entity.User">
       select * from user t
       order by t.login_name=REPLACE(#{req.currentUser},'\'','') desc
   </select>

上去吧,吴老二!

Mybatis order by 动态传参出现的问题及解决方法

问题比较简单,处理起来也是三下五除二,但是分析的过程还有点意思,所以发出来给大家瞧瞧。

来源:https://www.cnblogs.com/three-fighter/p/15055985.html

标签:Mybatis,order,by,传参
0
投稿

猜你喜欢

  • java判断用户输入的是否至少含有N位小数的实例

    2021-06-01 02:56:42
  • Android实现支付宝支付密码输入界面

    2023-06-20 14:57:15
  • 解析Android开发优化之:对Bitmap的内存优化详解

    2023-08-31 21:05:40
  • 仅4行代码实现Android快速文件下载

    2022-08-14 08:06:54
  • Spring实战之清除缓存操作示例

    2023-05-31 07:46:26
  • Android设置全屏代码分享

    2022-03-25 10:42:30
  •  Java SE 面向对象编程的3个常用接口

    2023-01-14 06:42:32
  • Android 图片添加水印的实现方法

    2023-11-20 01:13:29
  • 详解C#通过反射获取对象的几种方式比较

    2021-07-26 17:45:55
  • Java如何设置系统参数和运行参数

    2023-12-19 10:47:01
  • 详解java_ 集合综合案例:斗地主

    2022-02-08 04:14:49
  • C#实现图像锐化的方法

    2023-07-23 01:08:21
  • unity实现贴图矩阵运算(旋转平移缩放)

    2022-07-27 13:53:41
  • JDBC连接MySQL并实现模糊查询

    2021-07-06 01:42:28
  • JavaCV实现照片马赛克效果

    2023-04-27 15:55:14
  • java后台接受到图片后保存方法

    2023-06-03 09:23:04
  • Spring和activiti进行整合过程解析

    2023-04-20 05:30:19
  • spring配置不扫描service层的原因解答

    2022-03-24 16:35:02
  • 详解RestTemplate的三种使用方式

    2023-06-07 16:30:45
  • Android 8.0如何完美适配全局dialog悬浮窗弹出

    2023-04-09 12:54:00
  • asp之家 软件编程 m.aspxhome.com