gpt4 book ai didi

java - Spring Data Repository 中的转义值

转载 作者:行者123 更新时间:2023-12-01 11:27:00 25 4
gpt4 key购买 nike

我的 Spring 数据存储库中有以下内容:

@Query("select i from Image i where i.name like %:name% and deleted = false")
Collection<Image> findByName(@Param("name") String name);

该方法在数据库中搜索名称包含特定字符串的图像记录 - 因此是“like %:name%”。问题是,如果名称包含“like”运算符特有的字符(例如百分比或下划线),则不会对其进行转义。似乎这是由于 @Query 注释造成的 - 没有它,一切都会按预期工作。

如果我有一个名为“my%image”的图像并且想要搜索“y%”,则 SQL 将是“...like '%y\%%'

我的问题是如何让代码自动转义特殊字符?

最佳答案

我最终使用了 native 查询:

@Query(nativeQuery = true, value = "select * from asset where name like concat('%', replace(replace(:name, '%', '\\%'), '_', '\_'), '%')")

关于java - Spring Data Repository 中的转义值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30740432/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com