pgsql 使用JPA查询时,里面有问号,需要转义,应该怎么做才行啊,用了\转义不行
该回答通过自己思路及引用到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';
在上述查询中,两个问号会被解释为一个问号字符,从而避免了问号被解释为通配符的问题。
需要注意的是,双问号转义只适用于字符字面值中的问号,不能用于占位符。
如果以上回答对您有所帮助,点击一下采纳该答案~谢谢