无法为执行条件查询创建TypedQuery实例

时间:2016-08-14 12:03:24

标签: hibernate jpa criteria entitymanager javax.persistence

我是JPA的初学者。 我只想返回实体method getAll的所有实例。但是当我在WAR中收集我的项目时,我得到了这个错误error。 我不知道什么是问题。我的实体或背景可能有问题。     典型实体:

@Entity
public class Currency {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private long id;
private String name;



public Currency() {

}

public long getId() {
    return id;
}

public void setId(long id) {
    this.id = id;
}

public String getName() {
    return name;
}

public void setName(String name) {
    this.name = name;
}

}

上下文:

<beans xmlns="http://www.springframework.org/schema/beans"
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xmlns:context="http://www.springframework.org/schema/context"
   xmlns:jdbc="http://www.springframework.org/schema/jdbc" xmlns:tx="http://www.springframework.org/schema/tx"
   xsi:schemaLocation="http://www.springframework.org/schema/beans
   http://www.springframework.org/schema/beans/spring-beans.xsd
    http://www.springframework.org/schema/context
    http://www.springframework.org/schema/context/spring-context.xsd
    http://www.springframework.org/schema/tx
    http://www.springframework.org/schema/tx/spring-tx.xsd">

<context:annotation-config/>
<tx:annotation-driven/>

<context:component-scan base-package="ru.stasdev"/>

<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <property name="prefix" value="/WEB-INF/pages/"/>
    <property name="suffix" value=".jsp"/>
</bean>

<bean id="dataSource"
      class="org.apache.commons.dbcp.BasicDataSource">
    <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
    <property name="url" value="jdbc:mysql://localhost:3306/mydbtest"/>
    <property name="username" value="root"/>
    <property name="password" value="root"/>
    <property name="initialSize" value="3" />
    <property name="maxActive" value="10" />
</bean>

<bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
    <property name="dataSource" ref="dataSource"/>
    <property name="packagesToScan" value="ru.stasdev.domain"/>
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
            <prop key="hibernate.show_sql">true</prop>
            <prop key="hibernate.format_sql">true</prop>
        </props>
    </property>

</bean>

<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
    <property name="dataSource" ref="dataSource"/>
    <property name="packagesToScan" value="ru.stasdev"/>
    <property name="jpaVendorAdapter">
        <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
            <property name="showSql" value="true"/>
            <property name="database" value="MYSQL"/>
            <property name="databasePlatform" value="org.hibernate.dialect.MySQL5Dialect"/>
        </bean>
    </property>
</bean>

<bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource">
    <property name="basename" value="validation"/>
</bean>

<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
    <property name="entityManagerFactory" ref="entityManagerFactory"/>
</bean>

1 个答案:

答案 0 :(得分:0)

您似乎正在针对JPA 1.0进行编译,并且调用的方法位于JPA 2.0+(即EntityManager.createQuery(CriteriaQuery))。因此,您应该将正在编译的JPA API jar更正为v2.0或v2.1。

PS1。不知道你为什么不在你的帖子中用编译器错误和错误本身来发布代码(而不是你发布的代码,这显然与编译器错误无关)。

PS2。为什么你的配置中有一些Hibernate特定的东西,我不知道。你创建了一个EMF,所以使用它而不是一些Hibernate SessionFactory ......