weixin_41083434 2023-04-24 19:00 采纳率: 28.6%
浏览 7

pgsql转义问号失败问题

pgsql 使用JPA查询时,里面有问号,需要转义,应该怎么做才行啊,用了\转义不行

  • 写回答

1条回答 默认 最新

  • Leodong. 2023-04-24 19:15
    关注

    该回答通过自己思路及引用到GPTᴼᴾᴱᴺᴬᴵ搜索,得到内容具体如下:
    在 PostgreSQL 中,使用问号作为占位符时,会被解释为字符字面值中的通配符,而不是占位符。因此,如果您需要在 JPA 查询中使用问号,可以尝试使用?1?2 等形式的占位符,而不是简单的问号。

    例如,假设您要查询一个表中所有 name 字段以指定字符串开头的记录,可以编写以下 JPA 查询:

    String namePrefix = "John";
    entityManager.createQuery("SELECT e FROM Employee e WHERE e.name LIKE ?1")
                 .setParameter(1, namePrefix + "%")
                 .getResultList();
    

    在上面的查询中,我们使用了?1作为占位符,并将查询参数设置为namePrefix + "%", 这样就可以避免使用问号时出现的转义问题。

    如果您仍然需要在 SQL 查询中使用问号,可以使用双问号进行转义。例如:

    SELECT * FROM my_table WHERE my_column = 'hello ?? world';
    

    在上述查询中,两个问号会被解释为一个问号字符,从而避免了问号被解释为通配符的问题。

    需要注意的是,双问号转义只适用于字符字面值中的问号,不能用于占位符。


    如果以上回答对您有所帮助,点击一下采纳该答案~谢谢

    评论

报告相同问题?

问题事件

  • 修改了问题 4月24日
  • 创建了问题 4月24日

悬赏问题

  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 unity第一人称射击小游戏,有demo,在原脚本的基础上进行修改以达到要求
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)