首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Hibernate子查询detachedCriteria

Hibernate子查询detachedCriteria
EN

Stack Overflow用户
提问于 2012-10-26 03:00:15
回答 2查看 32.9K关注 0票数 8

如何在hibernate中编写一个包含多个子查询的子查询。例如

代码语言:javascript
复制
select * from project_dtls where project_id in  
  (select project_id from project_users where user_id =
  (select user_id from user_dtls where email='abc@email.com'))

我知道我们可以通过DetachedCriteria编写代码,但是找不到任何可以使用多个子查询的例子。

EN

回答 2

Stack Overflow用户

发布于 2012-10-26 03:08:47

下面是一个例子:

代码语言:javascript
复制
DetachedCriteria exampleSubquery = DetachedCriteria.forClass(MyPersistedObject.class)
    .setProjection(Property.forName("id"))
    // plus any other criteria...
    ;

Criteria criteria = getSession().createCriteria(ARelatedPersistedObject.class)
    .setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY)
    .add(Subqueries.propertyIn("myPersistedObjectId", exampleSubquery)));

对于多个子查询,可以使用像Restrictions.or()这样的布尔运算符:

代码语言:javascript
复制
DetachedCriteria anotherSubquery = DetachedCriteria.forClass(MyPersistedObject.class)
    .setProjection(Property.forName("id"))
    // plus any other criteria...
    ;

Criteria criteria = getSession().createCriteria(ARelatedPersistedObject.class)
    .setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY)
    .add(Restrictions.or(
        Subqueries.propertyIn("myPersistedObjectId", exampleSubquery),
        Subqueries.propertyIn("myPersistedObjectId", anotherSubquery)));
票数 7
EN

Stack Overflow用户

发布于 2018-05-01 03:22:04

完全使用分离的标准(因为我喜欢在没有会话的情况下构造分离的标准)

代码语言:javascript
复制
DetachedCriteria idQuery = DetachedCriteria.forClass(MyPersistedObject.class)
    .setProjection(Property.forName("id"))
DetachedCriteria recordQuery = DetachedCriteria.forClass(MyPersistedObject.class)
    .add(Property.forName("id").eq(idQuery) );
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13075390

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档