2017-05-06 49 views
0

我正在研究一个经常使用CriteriaBuilder.CoalesceRoot的大代码库。例如,设置CriteriaBuilder

criteriaBuilder.coalesce(root.get('adjustedWeight'), root.get('weight'))

我不明白这句法。举例来说,Coalesce API似乎只接受1个类型为Expression<? extends T>T的参数。我也不明白根是什么或为什么它是有用的。

为了帮助我理解,我使用CriteriaBuilder和Root创建了一个使用上面代码行的简化示例。我成功地连接了Hibernate和JPA。

请记住我有3天的Java编程经验。我的家乡是langugage C#

import models.MyEntity; 
import org.hibernate.jpa.HibernatePersistenceProvider; 

import javax.persistence.EntityManager; 
import javax.persistence.EntityManagerFactory; 
import javax.persistence.spi.PersistenceProvider; 
import java.util.HashMap; 
import java.util.List; 


public class Main { 
    public static final String SELECT_QUERY = "from MyEntity where title = :title"; 

    public static void main(String[] args) { 
      String title = "secureexam"; 
      PersistenceProvider persistenceProvider = new HibernatePersistenceProvider(); 
      EntityManagerFactory entityManagerFactory = persistenceProvider 
        .createEntityManagerFactory("NewPersistenceUnit", new HashMap()); 
      EntityManager entityManager = entityManagerFactory.createEntityManager(); 
      List<MyEntity> result = entityManager 
        .createQuery(SELECT_QUERY, MyEntity.class) 
        .setParameter("title", title) 
        .getResultList(); 

      System.out.println("result is " + result.get(0).getTitle()); 
      entityManager.close(); 
    } 
} 

能否请您解释的第一行代码给我关于criteriaBuilder?另外,如何修改我的代码以使用这一行代码?

UPDATE

凯文·彼得斯的回答中提到的文章稍作修改工作:

CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder(); 
    CriteriaQuery<Entity> criteriaQuery = criteriaBuilder.createQuery(Entity.class); 

//Test 1 
Root<AssessmentEntity> rootTest1 = criteriaQuery.from(Entity.class); 

换句话说,CriteriaBuilderCriteriaQuery必须以不同的方式实例化的构建工作。例如。整个CriteriaQuery<Entity class>语法对我来说没有意义。

回答

1

看来你有错误的API文档,正确的是this。 coalesce方法(如SQL pendant)只是返回第一个非空值,因此如果不为空,则返回adjustedWeight的值,否则返回weight的值,或者如果不存在任何值,则返回至少为null。

您的案例中的root变量仅代表您正在处理的表,它们分别表示查询的根(SQL查询翻译将为... FROM ...)。这个名字是任意的。 As database term this would be the selectionThis article也可以帮助你。