当前位置: 首页 > article >正文

【解决】sql中包含问号(?),导致mybatis解析错误

解决mybatis解析sql中问号报错

  • 存在问题
  • 解决方案一
  • 解决方案二

文章来自我的博客

存在问题

今天在使用 mybatis 处理动态 sql (PostgreSQL 数据库)的时候遇到了一个问题:
sql语句中本身包含 ? 的时候 mybatis 解析参数会把 sql语句中的 ?当作占位符 给解析成变量 导致sql查询失败
案例如下:
我这里存储的是jsonb类型数据 大概如下:

{
    "str": "param",
    "arr": [
        "param1",
        "param2"
    ]
}

我的需求是:想要获取json列的数据中数组arr中包含param1的数据 得到的sql如下:

SELECT *
FROM your_table
WHERE tags->'arr' ?| ARRAY['paam1'];

这个sql在我们的sql连接器中执行是完全没问题的,但是在mybatis中使用这个sql的时候?|中的?会被mybatis当作占位符 替换成参数
例子如下:

// 这里是mapper接口
public interface testMapper {
    List<User> getUser(@Param("sysId") String sysId);
}
<!--这里是xml文件-->
<select id="getUser" resultType="User">
        SELECT *
        FROM user
        WHERE tags -> 'arr' ?| ARRAY[#{sysId}]
</select>

假如我传入的sysIdaaa那么最后我们查询出来的sql就会变成:

SELECT * FROM user WHERE tags -> 'arr' 'aaa'| ARRAY[?] 

同时代码报错:

org.springframework.dao.DataIntegrityViolationException: 
### Error querying database.  Cause: org.postgresql.util.PSQLException: 未设定参数值 2 的内容。
### The error may exist in file [D:\ffcs-progect\back\gops-timing-calculation\target\classes\mybatis\AnalyNetElementMapper.xml]
### The error may involve com.ffcs.iod.app.modules.analy.mapper.NetElementMapper.test-Inline
### The error occurred while setting parameters
### SQL: SELECT *         FROM user         WHERE tags -> 'arr' ?| ARRAY[?]
### Cause: org.postgresql.util.PSQLException: 未设定参数值 2 的内容。
; 未设定参数值 2 的内容。; nested exception is org.postgresql.util.PSQLException: 未设定参数值 2 的内容。

由上可以看到?|运算符的?被替换了 而不是 我们参数 ,参数的位置还是空的。下面给出两种我测试都可以的方案,但是个人比较推荐第二种方案。

解决方案一

?| 写成??|也就是在问号的前面多加一个问号,这样就能解决了。
例如:

<select id="getUser" resultType="User">
        SELECT *
        FROM user
        WHERE tags -> 'arr' ??| ARRAY[#{sysId}]
</select>

这种方法虽然在解析的时候还是会显示如下sql:

SELECT * FROM user WHERE tags -> 'arr' 'aaa'?| ARRAY[?] 

但是代码是没有报错的,同时也可以查询出来数据。

解决方案二

使用pg数据库内置函数jsonb_exists_any(),这个方法比较推荐

<select id="getUser" resultType="User">
        SELECT *
        FROM user
        WHERE jsonb_exists_any(tags -> 'arr', ARRAY[#{sysId}])
</select>

http://www.kler.cn/a/284617.html

相关文章:

  • 【MySQL从入门到放弃】InnoDB磁盘结构(一)
  • 【教程】华南理工大学国际校区宿舍门锁声音设置
  • Stored procedures in PostgreSQL
  • SQL50题
  • HarmonyOS Next 实战卡片开发 02
  • YOLOv11融合ICCV[2023]动态蛇形卷积Dynamic模块及相关改进思路|YOLO改进最简教程
  • 使用 @Configuration 和 @Bean 注解替代 XML 配置文件
  • 使用pgdump、pgrestore迁移数据表到docker部署的postgis
  • Oracle数据库大小写问题注意点
  • 57基于SpringBoot+Vue+uniapp的洗衣店订单管理系统的详细设计和实现(源码+lw+部署文档+讲解等)
  • Spring Boot 框架中配置文件 application.properties 当中的所有配置大全
  • React教案
  • 关于报错 SLF4J: Failed to load class “org.slf4j.impl.StaticLoggerBinder“ 的可能原因
  • 软件测试面试八股文
  • LeetCode面试题Day18|LC61 旋转链表
  • 【web开发】Spring Boot 快速搭建Web项目(二)
  • Getting RateLimitError while implementing openai GPT with Python
  • openshift node NotReady kubelet http: TLS handshake error
  • SAP 有趣的‘bug‘ 选择屏幕输入框没了
  • 应用案例|亚克力板CNC加工自动化上下料
  • (四)进入MySQL 【事务】
  • 私有ip(介绍,地址范围),私网和公网的关系(访问外部网站的过程,NAT技术)
  • 三种评估金融风险的方法的具体Python实现:Stress Testing、Scenario Analysis和Sensitivity Analysis
  • 乐凡三防:工业界的硬核产品——重新定义三防平板的极限
  • Scrcpy手机投屏投屏到电脑上(windows/mac)
  • Python实现t-分布随机邻域嵌入(t-SNE)降维算法