- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试编写一个查询来从 Neo4J 数据库中提取数据。假设有五个条件决定我是否要从数据库中提取 _____:A、B、C、D 和 E。决定这一点的 bool 表达式是:
A && B && (C || D || E)
通过搜索网络,我找不到任何有关 Neo4J AND 和 OR 查询所遵循的操作顺序的信息(AND 通常先于 OR),但从我的观察来看,它们似乎是按顺序执行的。由于我不知道如何显式定义顺序(即使用括号),因此如何实现 Cypher 查询来满足上面的 bool 表达式?
最佳答案
there is no way that I know of to explicitly define order, aka using parenthesis
别那么肯定。 ;)
首先,总是存在关联或分组,即使在它们按顺序执行的情况下它是隐式的。让我们看一个重要的案例。
MATCH (n) RETURN CASE WHEN false AND true OR true THEN 'and' ELSE 'or' END
(只要数据库中至少有一个节点,这一点就可以工作。)
此必须等于((false and true) or true)
或(false and (true or true))
,但这些都有不同的结果。
(false and true) or true => false or true => true
false and (true or true) => false and true => false
上面的查询将在第一种情况下返回“and”,在第二种情况下返回“or”,以显示哪个先执行。它返回“and”,因为它们是按顺序分组的。
MATCH (n) RETURN CASE WHEN ((false AND true) OR true) THEN 'and' ELSE 'or' END
这也会返回“and”,因为这是按顺序执行 bool 运算符时得到的隐含分组。
MATCH (n) RETURN CASE WHEN (false AND (true OR true)) THEN 'and' ELSE 'or' END
但这会返回“或”。
这是一个非常冗长的方式来说明添加括号确实是答案。
只是为了好玩,我尝试确定优先级,看起来 Neo 确实有 and-优先级:
MATCH (n) RETURN CASE WHEN true or true and false THEN 'and' ELSE 'or' END
如果或首先分组:
(true or true) and false => true and false => false
如果 and 首先分组:
true or (true and false) => true or false => true
上面的查询返回“and”,表示隐式分组的构造整体评估为 true(因此,尽管 and 按顺序出现在最后,但仍先分组)。
关于Neo4j 密码查询语言 - bool 表达式的运算顺序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39239723/
为什么 (defun boolimplies (a b) (or (not a) b)) if called as(boolimplies 'a 'b) 返回 B? 即使我不使用任何 boolean
这个问题已经有答案了: Are there builtin functions for elementwise boolean operators over boolean lists? (5 个回答
我正在寻求帮助以使以下功能看起来更清晰。我觉得我可以通过使用更少的代码行来实现同样的目标。 标题看起来一定很困惑,所以让我详细说明一下。我创建了一个函数,它接受用户输入(即 72+5),将字符串拆分为
我正在学习 C++ 并尝试为矩阵编写一个 C++ 类,我在其中将矩阵存储为一维 C 数组。为此,我定义了一个 element成员函数根据矩阵元素在数组中的位置访问矩阵元素。然后我重载了 class
我正在学习 C++ 并尝试为矩阵编写一个 C++ 类,我在其中将矩阵存储为一维 C 数组。为此,我定义了一个 element成员函数根据矩阵元素在数组中的位置访问矩阵元素。然后我重载了 class
伙计们,以下内容不起作用 函数返回 true,变量返回 false,但它不会进入 when 子句。我尝试像这样放大括号 但是当我将变量的值设置为 true 并将上面的代码更改为 它进入w
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 9 年前。 Improve th
我是原生 C 语言的新手,但我没有看到错误。 我尝试在这种情况下使用 if 操作: #define PAGE_A 0 #define PAGE_B 1 int pageID = 0; if (page
我正在从事一个项目,让用户鼠标滚轮移动并知道它向上或向下滚动。在我的代码中,我可以上下移动。但我想将 Action 保存到一个字符串中。例如,如果用户向上向上向下滚动'mhmh' 显示返回“UUD”但
我有一个 MySQL 表 payment我在其中存储客户的所有付款相关数据。表字段为:fileNo , clientName , billNo , billAmount , status 。我想构建一
我的表架构如下: +------+-------+-------+
我有这个(顺便说一句,我刚刚开始学习): #include #include using namespace std; int main() { string mystr; cout << "We
我正在用 bash 构建一个用于 Linux (SLES 11SP3) 的脚本。我想通过使用以下语法查找它的 pid 来检查某个进程是否存在: pid="$(ps -ef | grep -v grep
我有一个包含两列的表格; CREATE TABLE IF NOT EXISTS `QUESTION_CATEGORY_RELATION` ( `question_id` int(16) NOT N
我对 Python 如何计算 bool 语句感到困惑。 例如 False and 2 or 3 返回 3 这是如何评估的?我认为 Python 首先会查看“False and 2”,甚至不查看“or
这个问题在这里已经有了答案: 12 年前关闭。 这可能是非常基本的......但我似乎不明白: 如何 (2 & 1) = 0 (3 & 1) = 1 (4 & 1) = 0 等等.. 上面的这种模式似
无论如何在Haskell中定义如下函数? or True True = True or True undefined = True or True False
如您所知,TCL 有一些数学函数,例如 罪 , 因 , 和 假设 在 中调用的expr 带有 的命令() 大括号如下: puts [expr sin(1.57)] 现在如何使用 TCL 添加功能 li
让我们考虑两个数组列表。 ArrayList list1 = new ArrayList(); list1.add(1); list1.add(2); list1.add(3); ArrayList
我想包含和排除使用AND和OR的专业知识,包括与AND和OR操作正常工作。但是,当将排除专家与AND和OR一起使用时,返回与3相同的结果计数。我使用的是1.4版 Elasticsearch 。帮助我解
我是一名优秀的程序员,十分优秀!