- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 Cypher 的新手,我正在尝试通过我正在尝试建立的一个小项目来学习它。
对于创建的每个想法
,我通过类别
连接标签
。Categories
仅充当 Tags
和 Thoughts
之间的中间层,这样做是为了改进查询,防止 Tag
重复并减少对象之间的关系。
为了防止创建具有相同值的新Tags
,我想到了以下查询:
CREATE (t: Thought {moment:timestamp(), message:'Testing new Thought'})
MERGE (t1: Tag{value: 'work'})
MERGE (t2: Tag{value: 'tasks'})
MERGE (t3: Tag{value: 'administration'})
MERGE (c: Category)
MERGE (t1)<-[u:CONSISTS_OF{index:0}]-(c)
MERGE (t2)<-[v:CONSISTS_OF{index:1}]-(c)
MERGE (t3)<-[w:CONSISTS_OF{index:2}]-(c)
MERGE (t)-[x:CATEGORIZED_AS{index: 0}]->(c)
这工作得很好,除了一件事:Thought
接收与所有创建的Categories
的关系。据我了解,我在 MERGE 查询中没有定义任何限制。
但是,我不知道如何对 CATEGORIZED_AS
关系应用限制?
我尝试将其添加到查询底部,但这不起作用:
WHERE (t)-[x]->(c)
知道如何应用我所需要的限制吗?
我忘了提及类别
的唯一联系:类别按特定顺序连接到一组固定的标签
。
例如,我有三个标签:
Category
与 Thought
匹配的唯一方式是 Category
与 Tags
具有以下关系:
任何其他关系顺序均无效,应创建新的类别
。
最佳答案
问题:使用MERGE
MERGE
将尝试在图中找到一个模式,如果找到该模式,它将返回它,否则它将尝试创建整个模式。这对每个 MERGE 子句单独起作用。因此,这对于 (n:Tag)
节点来说非常有效,并且符合预期,因为您只需要为图中的每个单词一个标签,但是当您尝试在查询中稍后出现问题时合并一个类别。
您想要做的是尝试找到使用这些 r 连接到这三个 (t:Tag)
节点的 (c:Category)
关系 (:Tag)-[r:CONSISTS_OF]-()
上的 .index 属性。但是,您正在运行四个合并子句,它们执行以下操作:
MERGE (c: Category)
查找或创建任何带有标签“Category”的节点c
。
MERGE (t1)<-[u:CONSISTS_OF{index:0}]-(c)
MERGE (t2)<-[v:CONSISTS_OF{index:1}]-(c)
MERGE (t3)<-[w:CONSISTS_OF{index:2}]-(c)
查找或创建该节点与 t1
之间的关系,然后是 t2
、t3
等。
如果您要运行该查询,然后将其中一个标签更改为不同的内容(例如“rest”),然后再次运行该查询,您会期望出现一个新类别。但它不会使用当前查询,它只会创建一个新标签,然后在第一个 MERGE
子句中查找现有的 (c:Category)
节点,然后在它和新标签之间创建关系。因此,您不会将两个类别分别链接到三个标签(共享两个标签),而是将四个标签全部链接到一个类别,并且关系上有重复的索引。
因此,您真正想要做的是使用 MERGE
来查找如下所示的复杂模式。
MERGE (t1)<-[:CONSISTS_OF {index:0}]-(c:Category)-[:CONSISTS_OF {index:1}]->(t2),
(t3)<-[:CONSISTS_OF {index:2}]-(c)
令人烦恼的是,这会给你一个语法错误,因为 cypher 目前无法合并这样的复杂模式。那么,创意就来了。
解决方案 1:使用 CASE
和 FOREACH
进行条件执行(简单)
对于这种情况,这是一个非常方便的转到,请参阅下面的注释查询。您实际上将拆分合并,使用OPTIONAL MATCH
来尝试找到模式,然后使用密码语法中的一个小技巧来CREATE
(如果我们找到它)不存在。
CREATE (t: Thought {moment:timestamp(), message:'Testing new Thought'})
MERGE (t1:Tag{value: 'work'})
MERGE (t2:Tag{value: 'abayo'})
MERGE (t3:Tag{value: 'rest'})
WITH *
// we can't merge this category because it's a complex pattern
// so, can we find it in the db?
OPTIONAL MATCH (t1)<-[:CONSISTS_OF {index:0}]-(c:Category)-[:CONSISTS_OF {index:1}]->(t2),
(t3)<-[:CONSISTS_OF {index:2}]-(c)
// the CASE here works in conjunction with the foreach to
// conditionally execute the create clause
WITH t, t1, t2, t3, c, CASE c WHEN NULL THEN [1] ELSE [] END AS make_cat
FOREACH (i IN make_cat |
// if no such category exists, this code will run as c is null
// if a category does exist, c will not be null, and so this won't run
CREATE (t1)<-[:CONSISTS_OF {index:0}]-(new_cat:Category)-[:CONSISTS_OF {index:1}]->(t2),
(t3)<-[:CONSISTS_OF {index:2}]-(new_cat)
)
// now we're not sure if we're referring to new_cat or cat
// remove variable c from scope
WITH t, t1, t2, t3
// and now match it, we know for sure now we'll find it
// alternatively, use conditional execution again here
MATCH (t1)<-[:CONSISTS_OF]-(c:Category)-[:CONSISTS_OF]->(t2),
(t3)<-[:CONSISTS_OF]-(c)
// now we have the category, we definitely want
// to create the relationship between the thought and the category
CREATE (t)-[:CATEGORIZED_AS]->(c)
RETURN *
解决方案 2:重构图表(困难)
我在这里没有包含查询 - 虽然如果需要的话我可以这样做 - 但另一种方法是重构你的图表,将标签附加到环(或链 - 带有最终成员标记)结构中的类别,以便您可以立即合并该模式,而无需将其拆分。
由于类别是按顺序排列的,因此您可以在一个 MERGE
子句中表达如下所示的数据。
MERGE (c:Category)-[:CONSISTS_OF_TAG_SEQUENCE]->(t1)-[:NEXT_TAG_IN_SEQUENCE]->(t2)-[:NEXT_TAG_IN_SEQUENCE]->(t3)-[:NEXT_TAG_IN_SEQUENCE]->(c)
乍一看这似乎是一个巧妙的解决方案,但问题是,由于标签属于多个类别,如果标签在类别之间共享,您将需要:
正如您可能已经猜到的那样,这将使您的查询比所需的速度要复杂得多。尝试起来可能很有趣,并且可能适合某些用例,但目前我会坚持使用简单的解决方案!
关于neo4j - 可选的关系合并,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45152257/
我已经在 OSX 上安装了 Docker 并下载了 neo 镜像。当我运行它时(使用图像主页中的 args),一切似乎都正常,但日志的最后几行表明如下: 00:20:39.662 [main] INF
我的正则表达式在 neos 项目中不能正常工作。DD/MM/YYYY 的正则表达式(仅限 19XX-20XX) var date_regex = /^(0[1-9]|1\d|2\d|3[01])\/(
Neo 4j可以与HDFS / Hadoop集成吗?在处理涉及许多关系且每秒具有大量事务的大型数据集时,通常使用Hadoop来提高Neo 4j的处理能力。 最佳答案 这是一个非常广泛的问题。也许考虑提
我尝试在 NEO 环境中使用 TenantAccessor。TenantAccessor.getCurrentTenant().getTenantId() 生成的 TenantId 作为 GUID 返
我下载了Neoclipse Source并下载了 Neo4J source 。但是 Neo4J 源文件中找不到 Neoclipse 源文件引用的某些类。它们已被弃用吗?我可以获得 Neoclipse
进程文件: neo or neo.exe 进程名称: Price Patrol 进程类别:存在安全风险的进程 英文描述: neo.exe is the execuatble for Pric
load csv with headers from 'file:///C:/Users/user/Desktop/Neo4J' as row Create (:State_Code {state_c
如何在 SAPUI5 应用程序的运行时为 neo-app.json 文件的 routes 部分定义新条目?例如在 Component.js 内部。 例如,我想将以下条目添加到文件中,或者将一些代码添加
我最近将一台计算机变成了 Ubuntu 服务器。我已经按照下面的文章 http://neos.readthedocs.io/en/stable/GettingStarted/Installation.
我正在尝试了解如何使用 NEOS Server for SCIP .我已经阅读了有关 CPLEX LP file format 的教程.但我仍然得不到任何结果。 让我们以该教程中提供的示例为例: Ma
关于这一年Bubble Cup (完)有问题NEO (我无法解决),它要求 给定一个包含 n 个整数元素的数组。我们把它分成几个部分(可能是1个),每个部分都是一个连续的元素。这种情况下的 NEO 值
我的 Rails 应用程序必须使用 Neo4j。所以我开始安装 neo4j 服务器。我按照步骤安装 here在 Linux 上。 但是当我运行的时候 ./bin/neo4j console 它给了 E
我刚从 windows 10 切换到 arch linux我想使用 (Neo)Vim 作为我的代码编辑器我已经完成了自动编译和模糊查找器但我不知道如何在 (Neo)Vim 中调试 任何帮助! 最佳答案
我想问一下,如何使用Spring boot找到Dijkstra。 我目前使用 spring-boot-starter-data-neo4j 库将 Neo4j 与我的 java 类映射。 我现在想使用
我正在尝试创建一个可以从 U2F token (例如 Java 语言的 Yubikey Neo)检索公钥和私钥的应用程序。我尝试在控制台中使用简单的扫描仪从 Yubikey Neo 获取任何内容,但它
我想用摩托罗拉68000汇编器写一个程序,目标平台是Neo Geo(九十年代的游戏机);这个问题很严重,我有一个我想实现的特定项目并且我有编程经验(虽然我现在主要是 Perl/R 编程,但我以前只接触
我使用自定义 Web 服务作为 neo4j 的非托管扩展。 这是 Neo4j 提供的详细信息,我已遵循该详细信息并创建了自己的非托管扩展。 http://neo4j.com/docs/stable/s
Typo3 Neos 是否原生支持元素的响应行为?例如像 css 网格类(col-sm-?? 或 col-md-??)这样的 Bootstrap ,或者我可以使用 Neos 通过 hidden-xs
我是为嵌入式板构建自定义 Linux 操作系统的新手 - 所以请忽略我的无知。 我有一个名为 NanoPi NEO 的开发板,它具有定制的 Debian Linux。现在开发板附带一个 .img 文件
我正在尝试使用脚本在 NEO4j db 中导入 csv 文件: LOAD CSV FROM "file:///dataframe6.txt" AS line RETURN count(*) 但我收到以
我是一名优秀的程序员,十分优秀!