我整天都在争吵,似乎无法得到我想要的结果。我想获取标签集合中具有特定标记的所有节点。
我正在使用这个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时遇到方法错误。所以我读了一下,似乎大多数人都有这样的解决方案。我只是无法弄清楚我在做什么愚蠢的事情。非常感谢任何帮助!
答案 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>();
}