首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何为特定的SQL编写hibernate标准?

如何为特定的SQL编写hibernate标准?
EN

Stack Overflow用户
提问于 2011-04-04 16:45:22
回答 1查看 128关注 0票数 0

我需要用ICriteria写类似的SQL:

表:

1级-- 2级-- 3级

SQL:

代码语言:javascript
复制
SELECT * FROM 2Lvl
WHERE 2Lvl.1LvlFK in
(
    SELECT 1Lvl.Id

    FROM 3Lvl 

    JOIN 2Lvl ON 3Lvl.2LvlFK = 2Lvl.Id 

    JOIN 1Lvl ON 2Lvl.1LvlFK = 1Lvl.Id  

    WHERE 3Lvl.Id = 123
)

很抱歉有这么具体的问题,但是我从前任员工那里继承了Hibernate的项目,我仍然不能理解hibernate-criteria。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-04-04 22:05:39

代码语言:javascript
复制
var subQuery = DetachedCriteria.For<Lvl3>("lvl3")
     .CreateAlias("Lvl2", "sublvl2", JoinType.InnerJoin)
     .CreateAlias("Lvl1", "lvl1", JoinType.InnerJoin)
     .Add(Restrictions.EqProperty("sublvl2.Id", "lvl2.Id")
     .Add(Restrictions.Eq("lvl3.Id", 123)
     .SetProjection(Projections.Property("lvl1.Id"));

Session.CreateCriteria<Lvl2>("lvl2")
     .Add(Subqueries.PropertyIn("Lvl1.Id", subQuery));

应该能行得通。从1Lvl开始,我对你的实体的名称做了一些假设,等等。不是有效的C#标识符。我还假设每个表的主键列是Id。还要注意的是,这不会产生您正在寻找的完全相同的SQL,但它会得到相同的结果。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5536309

复制
相关文章

相似问题

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