0

我需要通过 ICriteria 编写类似的 SQL:

表:

1Lvl -- 2Lvl -- 3Lvl

SQL:

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
)

对于这么具体的问题,我很抱歉,但我从 exemployee 那里继承了 Hibernate 的项目,但我仍然无法理解 hibernate-criteria。

4

1 回答 1

0
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,但它会为您提供相同的结果。

于 2011-04-04T14:05:38.687 回答