AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / coding / 问题

问题[neo4j](coding)

Martin Hope
Bahar
Asked: 2024-11-07 03:23:46 +0800 CST

使用 Neo4j 的 rdflib 解析器时如何添加列表作为属性值

  • 5

假设我有一个 RDF .ttl 文件,其中包括:

<https://example/Product_1> <http://www.w3.org/ns/dcat#keyword> "health".
<https://example/Product_1> <http://www.w3.org/ns/dcat#keyword> "fitness".
<https://example/Product_1> <http://www.w3.org/ns/dcat#keyword> "sports".

我注意到,如果我使用 rdflib 将这些数据导入 Neo4j,使用此处描述的代码,一切正常,但只会为我的产品导入关键字的一个值。这是有道理的,因为对于“键”, keyword我们只能有一个值。那么有没有办法让解析器解析我的 .ttl 文件,以便它创建类似以下内容的内容:

(n:Product {Keyword:["sports","fitness", "health"]})

neo4j
  • 1 个回答
  • 15 Views
Martin Hope
it_would_be_better
Asked: 2024-11-02 00:38:31 +0800 CST

Neo4j 中同一查询的执行时间各不相同

  • 5

我在 Neo4j 中运行相同的查询,并注意到执行时间差异很大。例如,查询可能在 5-6 秒内执行,而有时则需要 2-3 分钟,即使数据保持不变。

:param {
  idsToExclude: []
};

:auto LOAD CSV WITH HEADERS FROM ('file:///PERSON_DATA.csv') AS row
WITH row
WHERE NOT row.`person_id` IN $idsToExclude AND NOT row.`person_id` IS NULL
CALL {
  WITH row
  MERGE (n: `Person` { `person_id`: row.`person_id` })
  SET n.`person_id` = row.`person_id`
  SET n.`name` = row.`name`
  SET n.`age` = toInteger(row.`age`)
  SET n.`email` = row.`email`
  SET n.`address` = row.`address`
  SET n.`creation_date` = datetime(row.`creation_date`)
  SET n.`last_modified_date` = datetime(row.`last_modified_date`)
} IN TRANSACTIONS OF 5000 ROWS;

这是我的配置文件中的一些数据,如果需要的话,这些数据已被取消注释

server.memory.heap.initial_size=8G
server.memory.heap.max_size=16G
dbms.memory.transaction.total.max=32G

解释我的查询

第一部分 第二部分 第二部分

为什么在 Neo4j 中执行相同的查询会花费不同的时间?哪些因素会影响这一点,以及如何优化其性能?

neo4j
  • 1 个回答
  • 26 Views
Martin Hope
lkp
Asked: 2024-10-11 13:13:49 +0800 CST

是否有高效的方式来获取节点列表以及最新的相关节点?

  • 5

我有以下关系:

(Thread)-[:HAS_MESSAGE]->(Message)

一个线程可以包含数十条到数千条消息。

这是我的查询,用于查找线程列表,并返回每个线程的最新消息(如果存在)。

MATCH (t:Thread)
OPTIONAL MATCH (t)-[:HAS_MESSAGE]->(m:Message)
WITH t, m
ORDER BY m.createdAt DESC
WITH t, COLLECT(m)[0] AS latestMessage
RETURN t, latestMessage

我很难理解是否有办法重写它以避免COLLECT(m)[0]以某种方式仅使用最新消息?

neo4j
  • 2 个回答
  • 26 Views
Martin Hope
ning wu
Asked: 2024-09-27 10:16:35 +0800 CST

neo4j 3.5版本apoc.create.vRelationship不返回边属性

  • 7

这是我的 Cypher 声明:

match (first1:ent) where first1.nodeid in ['aab40c4d65d5c0a428ed84dc0109b0c4']
match (first2:ent) where first2.nodeid in ['000415fee2b0272cdcc2439f521b2e2e']
CALL apoc.create.vRelationship(first1,'teninvmerge',{conprop:'11'},first2) YIELD rel 
RETURN rel,rel.conprop

在此处输入图片描述

如何获取我直接设置的虚拟边的属性?

不知道是不是我的语句写得有问题,还是APOC 3.5版本不支持直接查询边属性,查了官方文档也没找到相关信息。

neo4j
  • 2 个回答
  • 29 Views
Martin Hope
notANerdDev
Asked: 2024-09-22 14:05:50 +0800 CST

Neo4J APOC 定期迭代 - ReferenceFromSlot(2) 是一个映射,但它是:“NO_VALUE”:4

  • 5

我有标签 TypeA 的节点,它有一个字符串属性 propA。propA 是一个字符串 JSON,可以使用 apoc.convert.fromJsonMap() 转换为映射。

我想创建 TypeB 的新节点,其属性为 propA,并在两个节点之间建立关系。我已成功运行以下查询:

MATCH (n:TypeA)
WITH apoc.convert.fromJsonMap(n.propA) AS values,n limit 1
MERGE (v:TypeB)
SET v=values
WITH n,v
MERGE (v)-[:RELATION_TYPE]->(n)
RETURN v,n;

但是,当我使用以下 apoc.periodic.iterate 来转换整个数据库时,它会引发错误。我运行的查询:

CALL apoc.periodic.iterate(
  "MATCH (n:TypeA) RETURN n;",
  "WITH apoc.convert.fromJsonMap(n.propA) AS values, n
   MERGE (v:TypeB)
   SET v=values
   WITH n,v
   MERGE (v)-[:RELATION_TYPE]->(n)
   RETURN v,n;
  ",
  {batchSize:10000, parallel: false});

错误:

{
  "Expected ReferenceFromSlot(2) to be a map, but it was :`NO_VALUE`": 4382
}

非常感谢您的帮助。

neo4j
  • 1 个回答
  • 31 Views
Martin Hope
Dev Scott
Asked: 2024-08-09 12:23:19 +0800 CST

Neo4j 获取摘要更新为 false,因为两个更新的同一字段为空

  • 6

我一直在关注 neo4j 查询

match (u:users {id: $id) set u.isOnline = null

它首次给出了将属性值设置为 1 的更新摘要,而当我再次重新运行查询时,它给出了相同值的 0。

但是当我运行这个查询时

match (u:users {id:$id}) set u.token = $token

无论我运行此查询多少次,它始终为我提供属性设置值的更新摘要为 1

neo4j
  • 1 个回答
  • 12 Views
Martin Hope
zakmck
Asked: 2024-06-10 23:52:24 +0800 CST

通过属性值高效搜索 Neo4j 关系

  • 5

在 Neo4j 中,我需要找到具有给定属性值的所有关系,独立于关系类型:

WITH ["1651365", "1188654", "1151147", ...] AS relIds
MATCH ()-[r]->() WHERE r.myId IN relIds
RETURN TYPE(r) AS type, properties ( r ) AS props;

这个查询有效,但速度很慢。如果我对其进行分析,我发现它基于全面扫描(1400 万个关系)。

问题是没有办法为所有关系类型定义索引(我可以对类型列表执行相同操作,引擎将使用为其定义的索引myId)。

有解决办法吗?使用时elementId(),引擎会执行查找操作,并且速度非常快,但文档不鼓励这样做(他们说内部ID在删除后会被重用)。

neo4j
  • 2 个回答
  • 33 Views
Martin Hope
Michael Thrift
Asked: 2024-06-05 21:55:39 +0800 CST

Neo4j - 添加大量关系 - 性能

  • 5

设置

我有一个 .NET 应用程序,它使用 Neo4j 客户端库在后端 Neo4j 数据库上执行 CRUD 操作。该数据库中的节点和关系代表公式和参数。

有两个节点标签:BusinessRule和ChartField。

对于每个节点,与某个节点之间BusinessRule存在单一关系,并且与代表公式参数的其他节点之间可能存在一对多的关系。OUTPUTSChartFieldUSESChartFieldBusinessRule

当用户完成所有规则的配置后,他们会发布更改,这将重建图表。

问题

我正在努力解决在图表中添加关系的性能问题。

在一次“发布”中,我可能有 3,000 个不同的BusinessRules。添加所有BusinessRule和ChartField节点的速度很快,并且性能不存在问题。

但是为这 3,000 个中的每一个添加关系BusinessRule需要很长时间。

下面是 Cypher 查询的示例,它将添加单个BusinessRule.它必须运行 3,000 次才能完成任务。我确实有Id两种节点类型的属性索引。

MATCH (p1:BusinessRule {Id: '2025-BUDGET-10000184-11061345'})  
MATCH (t1:ChartField {Id: '2025-BUDGET-11061345'})  
MATCH (v1:ChartField {Id: '2025-BUDGET-11061472'})  
MATCH (v2:ChartField {Id: '2025-BUDGET-11062722'})  
CREATE (p1)-[:OUTPUTS {Type: 'OUTPUTS', TargetCFID: 11061345, BusinessRuleId: '2025-BUDGET-10000184-11061345'}]->(t1)  
CREATE (p1)-[:USES {Type: 'USES', ParamCFID: 11061472, BusinessRuleId: '2025-BUDGET-10000184-11061345'}]->(v1)  
CREATE (p1)-[:USES {Type: 'USES', ParamCFID: 11062722, BusinessRuleId: '2025-BUDGET-10000184-11061345'}]->(v2)

该查询通过匹配相关的BusinessRule和ChartField节点来工作,其中 p1 是BusinessRule,t1 是目标ChartField节点,v* 是ChartField参数。然后,我们可以添加关系。

有人对如何加快这个过程有什么建议吗?执行这个密码(3,000)次花费了近 22 分钟。

我考虑过将最多 100 个密码查询批处理在一起,以节省来回的时间,但这有点复杂,因为别名必须都是唯一的。

在一些批处理测试中,我看到了一些改进,但没有什么显着的。

neo4j
  • 1 个回答
  • 26 Views
Martin Hope
Sam Wynne
Asked: 2024-05-05 03:03:12 +0800 CST

Neo4j Cypher:如果找到一个匹配项,如何停止检查多个 OPTIONAL MATCH 子句?

  • 6

我试图检查是否存在任何一种关系组合,但我只关心是否至少存在一种。由于遍历的复杂性增加,如果我可以在第一次匹配时中断并返回查询,那就太理想了。

例子:

MATCH (p:Person { id: "user_1" }), (m:Movie { id: "movie_x" })
OPTIONAL MATCH (p)-[acted:ACTED_IN]->(m)
OPTIONAL MATCH (p)-[directed:DIRECTED]->(m)
OPTIONAL MATCH (p)-[:ACTED_IN]->(:Movie)<-[:PRODUCED_BY]-(:Studio)-[sibling_actor:PRODUCED_BY]->(m)
OPTIONAL MATCH (p)-[:DIRECTED]->(:Movie)-[:OF_TYPE]->(:Genre)<-[sibling_director:OF_TYPE]-(m)
RETURN count(acted) > 0 AS actedInMovie, count(directed) > 0 AS directedMovie, count(sibling_actor) > 0 AS actedInSibling, count(sibling_director) > 0 AS directedSibling

这将返回这些模式中每个模式存在的真实性,但由于我只关心是否有一个匹配,因此如果第一个找到匹配,我不想运行所有四个可选匹配。

neo4j
  • 1 个回答
  • 20 Views
Martin Hope
bAN
Asked: 2024-04-11 21:36:38 +0800 CST

在WITH语句中使用apoc函数

  • 5

我想将 apoc 函数与WITH语句一起使用,但每次都会出错。当直接在语句中调用该函数时,CALL这是有效的:

CALL apoc.ml.openai.embedding(['Some Text'], ...

WITH但是当我在语句中包含函数调用时

MATCH (movie:Movie) WHERE movie.tagline IS NOT NULL
WITH movie, apoc.ml.openai.embedding(movie.tagline, 

我有一个函数未知错误:message: Unknown function 'apoc.ml.openai.embedding'

任何想法?

neo4j
  • 1 个回答
  • 10 Views

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    重新格式化数字,在固定位置插入分隔符

    • 6 个回答
  • Marko Smith

    为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会?

    • 2 个回答
  • Marko Smith

    VScode 自动卸载扩展的问题(Material 主题)

    • 2 个回答
  • Marko Smith

    Vue 3:创建时出错“预期标识符但发现‘导入’”[重复]

    • 1 个回答
  • Marko Smith

    具有指定基础类型但没有枚举器的“枚举类”的用途是什么?

    • 1 个回答
  • Marko Smith

    如何修复未手动导入的模块的 MODULE_NOT_FOUND 错误?

    • 6 个回答
  • Marko Smith

    `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它?

    • 3 个回答
  • Marko Smith

    在 C++ 中,一个不执行任何操作的空程序需要 204KB 的堆,但在 C 中则不需要

    • 1 个回答
  • Marko Smith

    PowerBI 目前与 BigQuery 不兼容:Simba 驱动程序与 Windows 更新有关

    • 2 个回答
  • Marko Smith

    AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String”

    • 1 个回答
  • Martin Hope
    Fantastic Mr Fox msvc std::vector 实现中仅不接受可复制类型 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant 使用 chrono 查找下一个工作日 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor 构造函数的成员初始化程序可以包含另一个成员的初始化吗? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský 为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul C++20 是否进行了更改,允许从已知绑定数组“type(&)[N]”转换为未知绑定数组“type(&)[]”? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann 为什么 {2,3,10} 和 {x,3,10} (x=2) 的顺序不同? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller 在 5.2 版中,bash 条件语句中的 [[ .. ]] 中的分号现在是可选的吗? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench 为什么双破折号 (--) 会导致此 MariaDB 子句评估为 true? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng 为什么 `dict(id=1, **{'id': 2})` 有时会引发 `KeyError: 'id'` 而不是 TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String” 2024-03-20 03:12:31 +0800 CST

热门标签

python javascript c++ c# java typescript sql reactjs html

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve