加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

带有JPA 2.0 ClassCastException的Spring 3.0 ORM

发布时间:2020-12-15 01:44:52 所属栏目:大数据 来源:网络整理
导读:我试图在Spring 3.0 ORM中使用JPA 2.0. JPA供应商是Hibernate 3.5.0-Beta-3. 它适用于JPQL,但是当我尝试使用CriteriaQuery时,会发生异常: java.lang.ClassCastException: $Proxy50 cannot be cast to javax.persistence.TypedQuery at $Proxy38.createQuery

我试图在Spring 3.0 ORM中使用JPA 2.0. JPA供应商是Hibernate 3.5.0-Beta-3.

它适用于JPQL,但是当我尝试使用CriteriaQuery时,会发生异常:

java.lang.ClassCastException: $Proxy50
cannot be cast to
javax.persistence.TypedQuery at
$Proxy38.createQuery(Unknown Source)
at
com.absorbx.retailx.dao.impl.ShopDaoImpl.findByCrieria(ShopDaoImpl.java:30)
at
com.absorbx.retailx.dao.SimpleDaoTest.testFindByCriteria(SimpleDaoTest.java:39)
at
sun.reflect.NativeMethodAccessorImpl.invoke0(Native
Method) at
sun.reflect.NativeMethodAccessorImpl.invoke(Unknown
Source) at
sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown
Source)

DAO代码:

@Repository
public class ShopDaoImpl implements
ShopDao {
    @PersistenceContext
    transient EntityManager entityManager;

    @Override
    public Shop findByCrieria() {
        CriteriaBuilder cb = entityManager.getCriteriaBuilder();
        CriteriaQuery

我该如何解决这个问题?

最佳答案
它似乎是Spring中的一个错误:

组织/ springframework的/ ORM / JPA / SharedEntityManagerCreator.java:

if (result instanceof Query) {
    Query query = (Query) result;
    ...
    result = Proxy.newProxyInstance(Query.class.getClassLoader(),new Class[] {Query.class},new DeferredQueryInvocationHandler(query,target));
    ...
}

最好是创建一个问题.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读