Hibernate子查询上的ClassCastException
下面的代码有问题。类id是长的,B类id是嵌入的id,其中一个字段是类Hibernate子查询上的ClassCastException,hibernate,subquery,classcastexception,Hibernate,Subquery,Classcastexception,下面的代码有问题。类id是长的,B类id是嵌入的id,其中一个字段是类 DetachedCriteria dc = DetachedCriteria.forClass(A.class,"a").setProjection(Property.forName("a.id")); Criteria cr= this.sessionFactory.getCurrentSession().createCriteria(B.class,"b").add(Subqueries.in("b.id.a
DetachedCriteria dc = DetachedCriteria.forClass(A.class,"a").setProjection(Property.forName("a.id"));
Criteria cr= this.sessionFactory.getCurrentSession().createCriteria(B.class,"b").add(Subqueries.in("b.id.a.id", dc));
List<B> bb = cr.list();
但这是:
List<Long> dd = this.sessionFactory.getCurrentSession().createCriteria(A.class,"a").setProjection(Property.forName("a.id")).list();
Criteria cr= this.sessionFactory.getCurrentSession().createCriteria(B.class,"b").add(Restrictions.in("b.id.a.id", dd));
List<B> bb = cr.list();
工作。我做错了什么?在这种情况下应该使用subquerys.propertyIn
List<Long> dd = this.sessionFactory.getCurrentSession().createCriteria(A.class,"a").setProjection(Property.forName("a.id")).list();
Criteria cr= this.sessionFactory.getCurrentSession().createCriteria(B.class,"b").add(Restrictions.in("b.id.a.id", dd));
List<B> bb = cr.list();