谁能提供一个使用CriteriaBuilder编写案例查询的示例吗?

最佳答案

以下是使用CriteriaBuilder的示例案例表达式(在JPA 2中有效):

Hashtable caseTable = new Hashtable(3);
caseTable.put("Bob", "Bobby");
caseTable.put("Susan", "Susie");
caseTable.put("Eldrick", "Tiger");
Expression expression = builder.get("firstName").caseStatement(caseTable, "NoNickname").equal("Bobby");

它生成以下SQL查询:
"CASE t1.firstName WHEN 'Bob' THEN 'Bobby' WHEN 'Susan' THEN 'Susie' WHEN 'Eldrick' THEN 'Tiger' ELSE 'NoNickname' END = 'Bobby'"

有关更多信息,请参见JPA 2.0 Case Expressions

09-04 14:24