JPA中Criteria Builder中的ignorecase是什么意思?

24

如何在Criteria Builder中进行忽略大小写?如果我有

private final CriteriaBuilder cb

那么我只能使用 cb.asc 或者 cb.desc,但不能忽略大小写。


可能是重复的问题JPA2:不区分大小写的模糊匹配的可能副本。 - weltraumpirat
没有帮助的链接。 - ronan
应该这样做。正如您所指出的,CriteriaBuilder没有启用ignorecase的选项。因此,只需将搜索词和结果转换为大写或小写,就可以实现相同的效果。 - weltraumpirat
我使用了CriteriaQuery查询,并使用了orderBy表达式。 - ronan
1个回答

60

如何在 Criteria Builder 中忽略大小写

1. 在 JPA 程序中强制忽略大小写 - 直接回答问题,解决方法

  • 对于一个单参数操作(例如 ORDER BY),将参数转换为小写(或大写)。
  • 对于一个双参数操作(例如 = 或 LIKE 或 ORDER BY),将两个参数都转换为小写(或大写)。

JPA ORDER BY 两个列并忽略大小写:

 Order lcSurnameOrder = criteriaBuilder.order(
     criteriaBuilder.lower(Person_.surname));
 Order lcFirstnameOrder = criteriaBuilder.order(
     criteriaBuilder.lower(Person_.firstname));    
 criteriaQuery.orderBy(lcSurnameOrder, lcFirstnameOrder);

JPA LIKE, 忽略大小写:

 Predicate lcSurnameLikeSearchPattern = criteriaBuilder.like(
     criteriaBuilder.lower(Person_.surname), 
     searchPattern.toLowerCase());
 criteriaQuery.where(lcSurnameLikeSearchPattern);

假设原始内容为:

假设Person_规范元模型类是从Person实体生成的,以便在JPA条件API中提供强类型使用。

提示:为获得最佳性能和控制,请考虑将字符串列转换为小写或INITCAP大小写一次 - 在插入/更新到数据库时执行。 对于用户输入的搜索模式进行相同的转换。

2.备选方案:在数据库中应用排序规则 - 最佳实践、更简单、更高效

  • SQL-99标准具有内置的修改器,可根据规则比较字符串中的字符:

COLLATE <collation name>

可用于字符串比较、排序和分组。一个常见的忽略大小写的例子:

COLLATE SQL_Latin1_General_CP1_CI_AS

或者

COLLATE latin1_general_cs

你甚至可以创建自己的自定义排序规则:

CREATE COLLATION <collation name> FOR <character set specification>
  FROM <existing collation name> [ <pad characteristic> ]
  • 在数据库中应用排序规则的方式有以下几种(从本地化到全球适用):

    • WHERE 子句(=,LIKE,HAVING,>,>=等)

  • WHERE <expression> = <expression> [COLLATE <collation name>]
    
    WHERE <expression> LIKE <expression> [COLLATE <collation name>]
    
  • SELECT DISTINCT子句

    SELECT DISTINCT <expression> [COLLATE <collation name>], ...
    
  • ORDER BY 子句

    ORDER BY <expression> [COLLATE <collation name>]
    
  • GROUP BY子句

    GROUP BY <expression> [COLLATE <collation name>]
    
  • 列定义

    CREATE TABLE <table name> (
      <column name> <type name> [DEFAULT...] 
                                [NOT NULL|UNIQUE|PRIMARY KEY|REFERENCES...]
                                [COLLATE <collation name>], 
      ...
    )
    
  • 领域定义

    CREATE DOMAIN <domain name> [ AS ] <data type>
      [ DEFAULT ... ] [ CHECK ... ] [ COLLATE <collation name> ]
    
  • 字符集定义

    CREATE CHARACTER SET <character set name>
    [ AS ] GET <character set name> [ COLLATE <collation name> ]
    
  • 前四种情况无法与JPA一起使用,因为这些SQL命令是由JPA生成的,而JPA标准不支持校对。

  • 最后三种情况可以与JPA一起使用。
  • 因此:创建具有打开校对的列的表,然后ORDER BY,=,LIKE等将自动忽略大小写。 然后在JPA中不需要进行任何转换或请求以忽略大小写。
  • 3.替代(专有)Oracle还提供了NLS设置,以跨整个DB实例忽略大小写(可在配置文件中设置):

    ALTER SESSION SET NLS_COMP='BINARY';    -- Case Sensitive
    ALTER SESSION SET NLS_COMP='ANSI';      -- Ignore for LIKE but not =,<,etc
    ALTER SESSION SET NLS_COMP='LINGUISTIC';-- Ignore for LIKE,=,<,etc (post 10gR2)
    
    ALTER SESSION SET NLS_SORT='BINARY' ;   -- Case Sensitive
    ALTER SESSION SET NLS_SORT='BINARY_CI'; -- Ignore
    ALTER SESSION SET NLS_SORT='XSPANISH';  -- Ignore according to language rules
    ALTER SESSION SET NLS_SORT='LATIN1_GENERAL_CS';  
    

    添加忽略大小写的功能,仅限一次性使用。

    ORDER BY NLSSORT(supplier_name,'NLS_SORT=BINARY_CI') ;
    
    您可以通过以下方式调用此函数:
    criteriaBuilder.function("nlssort", String.class, dept_.suppler_name, "NLS_SORT=BINARY_CI");
    

    然后调用criteriaQuery.orderyByselect等方法。


    5
    Person_.surname 是如何定义的? - Vlastimil Ovčáčík
    @VlastimilOvčáčík,这个叫做MetaModel,请查看https://www.baeldung.com/hibernate-criteria-queries-metamodel。 - MevlütÖzdemir

    网页内容由stack overflow 提供, 点击上面的
    可以查看英文原文,
    原文链接