Jos*_*ina 0 hibernate subquery detachedcriteria
作用域是获取所有Bid由AND创建的元素, userId并且是Project projectIdAND 的一部分,其中存在 a Decision,Bid其上的Verb.verbString 是"accepted"。
但是,我得到了一个
org.hibernate.HibernateException: Unknown entity: null
Run Code Online (Sandbox Code Playgroud)
尝试将其实现为以下查询和子查询对时的异常:
DetachedCriteria accepedBidIds = DetachedCriteria.forClass(DecisionOnBid.class, "dec")
.createAlias("dec.bid", "dec_bid")
.add(Restrictions.eq("verb.verb", "accepted"))
.setProjection(Projections.property("dec_bid.id"));
Criteria query = sessionFactory.getCurrentSession().createCriteria(Bid.class).createAlias("cbtion.project","proj");
query.add(Restrictions.and(
Restrictions.like("creator.id", userId),
Restrictions.like("proj.id", projectId),
Subqueries.eq("id", accepedBidIds)));
List<Bid> bids = (List<Bid>) query.list();
Run Code Online (Sandbox Code Playgroud)
这些是我的实体。我故意避免双向依赖。
@Entity
@Table( name = "bids" )
public class Bid {
@Id
@GeneratedValue(generator="increment")
@GenericGenerator(name="increment", strategy = "increment")
private int id;
@ManyToOne
private Cbtion cbtion = new Cbtion();
@ManyToOne
private User creator = new User();
...
}
@Entity
@Table( name = "cbtions" )
public class Cbtion {
@Id
@GeneratedValue(generator="increment")
@GenericGenerator(name="increment", strategy = "increment")
private int id;
@ManyToOne
private Project project;
@ManyToOne
...
}
@Entity
@Table( name = "decisions_on_bids" )
public class DecisionOnBid extends Decision {
@ManyToOne
private Verb verb;
@OneToOne
private Bid bid;
...
}
Run Code Online (Sandbox Code Playgroud)
我尝试了一些别名的组合,但无法得到正确的组合。有什么建议吗?
这最终对我有用:
DetachedCriteria accepedBidIds = DetachedCriteria.forClass(DecisionOnBid.class, "d")
.createAlias("d.verb", "d_v")
.add(Restrictions.eq("d_v.verb", "accept"))
.createAlias("d.bid", "d_b")
.setProjection(Projections.property("d_b.id"));
Criteria query = sessionFactory.getCurrentSession().createCriteria(Bid.class,"b")
.add(Restrictions.eq("creator.id", userId))
.createAlias("b.cbtion","b_c")
.createAlias("b_c.project","b_c_p")
.add(Restrictions.eq("b_c_p.id", projectId))
.add(Subqueries.propertyIn("b.id", accepedBidIds));
@SuppressWarnings("unchecked")
List<Bid> bids = (List<Bid>) query.list();
Run Code Online (Sandbox Code Playgroud)
并非所有更改都需要。我认为关键是使用了很多别名,特别createCriteria(Bid.class,"b")是一开始我不清楚。
| 归档时间: |
|
| 查看次数: |
4029 次 |
| 最近记录: |