nHibernate queryover复杂查询

时间:2012-07-19 14:57:38

标签: c# nhibernate queryover

我整天都在争吵,似乎无法得到我想要的结果。我想获取标签集合中具有特定标记的所有节点。

我正在使用这个QueryOver命令但是我得到了所有可能的节点,即使它看起来像我应该只有一个。

    public IEnumerable<Node> GetAllWithTag(int tagId)
    {
        tags = new List<Tag>();
        Node node = null;
        Tag tagQ = null;

        var subQuery = QueryOver.Of<Tag>(() => tagQ)
            .Where(tag1 => tag1.Id == tagId).DetachedCriteria;

        subQuery = subQuery.SetProjection(Projections.Property("Id"));

        var nodes = _applicationUnitOfWork.GetSession().QueryOver<Node>(
            () => node).Where(Subqueries.Exists(subQuery)).List<Node>();

        return nodes;
    }

我正在使用这个奇怪的设置,因为当我尝试在node.Tags上使用Contains时遇到方法错误。所以我读了一下,似乎大多数人都有这样的解决方案。我只是无法弄清楚我在做什么愚蠢的事情。非常感谢任何帮助!

1 个答案:

答案 0 :(得分:2)

您是否尝试过使用JoinQueryOver or JoinAlias

这样的事情:

public IEnumerable<Node> GetAllWithTag(int tagId)
{
    return _applicationUnitOfWork.GetSession().QueryOver<Node>()
        .JoinQueryOver<Tag>(n => n.Tags)
            .Where(t => t.Id == tagId)
            .List<Node>();
}