2

我已经在我的 C# Web 应用程序中使用 NHibernate 完成了 OR 映射。当我想获取所有叶节点时,我使用如下查询语句:

List<NODE> LeafList =(List<NODE>) Session.CreateQuery("from NODE as node where node.Id not in (select FatherNodeId from NODE)").List<NODE>();

但是,查询后我得到 LeafList 的计数等于 0。我的数据库是这样的:

Id FatherNodeId
1   NULL
3    1
4    3
5    3

所以,我的预期结果应该是 id 为 4 或 5 的节点。更令人困惑的是,如果我将“not in”更改为“in”,则查询运行良好,并返回 id 为 1 或 3 的节点。

那么我的不在子查询中有什么问题?

4

2 回答 2

0

那么我的不在子查询中有什么问题?

这是一个非常重要的问题,因为一旦知道,在使用 NULL 值时永远不应忘记这个问题。

问题不在于 NH 或 .Net。它具有涉及 NULL 的布尔表达式的语义。任何涉及 NULL 的布尔表达式永远不会为真(这并不意味着它总是会为假),任何涉及结果的表达式都永远不会为真。

因此,这些 where 子句似乎始终为真的查询永远不会返回任何结果,因为它们永远不会解析为 true :

select 1 where (null=null) or not(null=null)

select 1 where (1=null) or not(1=null)

select 1 where (1<>null) or not(1<>null)

您的查询应该是这样的(不太熟悉 HQL)

from NODE as node 
    where not exists 
        ( from NODE as child where child.FatherNodeId = node.Id )
于 2013-09-25T08:04:42.693 回答
0

使用Not exist关键词

尝试这个 。

from NODE as node where node.Id not exists ( select  FatherNodeId from NODE)
于 2013-09-25T05:27:02.087 回答