JPQL:将Long转换为String以执行LIKE搜索

Kaw*_*awu 9 java jpa jpql long-integer sql-like

我有以下JPQL查询:

SELECT il
FROM InsiderList il
WHERE ( il.deleteFlag IS NULL OR il.deleteFlag = '0' )
  AND il.clientId = :clientId
  AND (    LOWER( il.name ) LIKE :searchTerm
        OR il.nbr LIKE :searchTerm
        OR LOWER( il.type ) LIKE :searchTerm
        OR LOWER( il.description ) LIKE :searchTerm )
Run Code Online (Sandbox Code Playgroud)

客户希望我们能够搜索该nbr字段,这是一个java.lang.Long.

:

如何java.lang.Long使用JPQL 执行LIKE搜索?

Dhe*_*rik 5

您可以CAST在 HQL 中使用:

SELECT il
FROM InsiderList il
WHERE ( il.deleteFlag IS NULL OR il.deleteFlag = '0' )
  AND il.clientId = :clientId
  AND (    LOWER( il.name ) LIKE :searchTerm
        OR CAST( il.nbr as string ) LIKE :searchTerm
        OR LOWER( il.type ) LIKE :searchTerm
        OR LOWER( il.description ) LIKE :searchTerm )
Run Code Online (Sandbox Code Playgroud)

但是这样做可能会遇到严重的性能问题,因为数据库将无法使用nbr索引(如果对nbr列进行了索引)。