4

我有一个 JPA 实体,它有两个属性可以通过“OR”运算符而不是“AND”进行搜索。这些是 ledgerCode 和部门:

Company comp = new Company();
ExampleMatcher matcher =
    ExampleMatcher.matching().withStringMatcher(StringMatcher.CONTAINING)
        .withIgnoreCase("name");

comp.setCountryCode(countryCode);
comp.setLedgerCode(ledgerCode);
comp.setDivision(division);
comp.setName(name);

List<Company> result = compSearchRepository.findAll(Example.of(comp, matcher));

那么 SQL 结果应该是(假设所有参数不为空):

SELECT d 
  FROM COMPANY d 
 WHERE d.countryCode = country 
    OR d.ledgerCode = ledger 
    OR d.division = division 
   AND lower(d.name) LIKE '%name%'

可能吗?如果是,怎么会?我在 Google 上找不到任何代码示例,也找不到在 ExampleMatcher 类中的建议方法名称。

4

1 回答 1

3

您不能将 OR 和 AND 搜索与 Query By Example 结合使用。

使用该方法ExampleMatcher.matchingAny()生成 OR 操作而不是 AND 操作。但是此操作用于每个属性。

于 2017-07-25T12:50:04.067 回答