- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我觉得我在这里做了很多额外的工作,因为有些我不知道的事情会让事情变得更容易!
基本上,我正在尝试获取用户的访问者以及访问者。
1)这是我当前使用的查询:
MATCH (you:User {user_id: { id }})
WITH you
OPTIONAL MATCH(you)-[yvr:VISIT]->(youVisited:User)
WITH you, collect(youVisited) as youVisited, collect(yvr) as yvr
OPTIONAL MATCH (visitedYou:User)-[vyr:VISIT]->(you)
WITH youVisited, collect(visitedYou) as visitedYou, collect(vyr) as vyr, yvr
RETURN
youVisited,
visitedYou,
yvr,
vyr,
length(filter(m in vyr where m.seen = false)) as unseenCount
(底部被切断,但 youVisited
到 yvr
, visitedYou
到 vyr
,右侧被切断,但 unseenCount
在那里)
╒══════════════════════════════╤══════════════════════════════╤══════════════════════════════╤══════════════════════════════╤═════════════╕
│"youVisited" │"visitedYou" │"yvr" │"vyr" │"unseenCount"│
╞══════════════════════════════╪══════════════════════════════╪══════════════════════════════╪══════════════════════════════╪═════════════╡
│[{"user_id":"auth0|58784f52734│[{"user_id":"auth0|5865bfa8087│[{"created_at":1484294208011,"│[{"created_at":1484317325539,"│2 │
│b0307b61ea401"},{"user_id":"au│52725eaaae8f9"},{"user_id":"au│seen":false},{"created_at":148│seen":false},{"created_at":148│ │
│th0|587805cb995ac47e7dbe42ae"}│th0|587805cb995ac47e7dbe42ae"}│4294735987,"seen":false},{"cre│4321428350,"seen":false}] │ │
│,{"user_id":"auth0|5865bfa8087│] │ated_at":1484293423029,"seen":│ │ │
│52725eaaae8f9"},{"user_id":"au│ │false},{"created_at":148429420│ │ │
│th0|58669ac4d4aed25972f7c33e"}│ │1140,"seen":false},{"created_a│ │ │
│,{"user_id":"auth0|586a0337b94│ │t":1484294214268,"seen":false}│ │ │
│a4d77c1f77cb3"}] │ │] │ │ │
└──────────────────────────────┴──────────────────────────────┴──────────────────────────────┴──────────────────────────────┴─────────────┘
2)所以我不知道该怎么办! 我想要得到created_at
youVisited
的, visitedYou
项目,但我不知道如何在查询期间合并它们,所以我最终弄得一团糟:
const nodes = {
youVisited: row.get('youVisited').map((yv, index) => Object.assign(
yv.properties,
{ created_at: row.get('yvr')[index].properties.created_at },
)),
visitedYou: row.get('visitedYou').map((vy, index) => Object.assign(
vy.properties,
{ created_at: row.get('vyr')[index].properties.created_at },
)),
unseenCount: row.get('unseenCount'),
};
3)然后我必须获取其他数据并再次找到 map ......
const youVisitedPromises = nodes.youVisited.map(yv => usersIndex.getObject(yv.user_id));
const visitedYouPromises = nodes.visitedYou.map(vy => usersIndex.getObject(vy.user_id));
let [youVisited, visitedYou] = await Promise.all([
youVisitedPromises, visitedYouPromises,
].map(Promise.all, Promise));
youVisited = youVisited.map(yv => Object.assign(
yv,
{ visited_at: _.get(_.find(nodes.youVisited, { user_id: yv.objectID }), 'created_at') },
));
visitedYou = visitedYou.map(vy => Object.assign(
vy,
{ visited_at: _.get(_.find(nodes.visitedYou, { user_id: vy.objectID }), 'created_at') },
));
result = {
youVisited,
visitedYou,
unseenCount: nodes.unseenCount,
};
我认为,如果我在步骤 1) 中执行某些操作,而不是返回两个彼此相关的单独数组,那么这可能会变得容易得多,例如youVisited
至yvr
,我只有一个数组,其中的对象包含所有数据 youVisited: [{ user_id, created_at, seen }, ...]
。如何使用 Neo4j 执行此操作?
预计最终result
我最终需要的看起来像:
result = {
youVisited: [{ user_id: 'a', nickname: 'foo', visited_at: 12931093 }, ...],
visitedYou: [{ user_id: 'b', nickname: 'bar', visited_at: 12931099 }, ...],
unseenCount: 1,
};
完整代码(如果还有其他可以帮助的内容):
const cypherGetVisitors = `
MATCH (you:User {user_id: { id }})
WITH you
OPTIONAL MATCH(you)-[yvr:VISIT]->(youVisited:User)
WITH you, collect(youVisited) as youVisited, collect(yvr) as yvr
OPTIONAL MATCH (visitedYou:User)-[vyr:VISIT]->(you)
WITH youVisited, collect(visitedYou) as visitedYou, collect(vyr) as vyr, yvr
RETURN
youVisited,
visitedYou,
yvr,
vyr,
length(filter(m in vyr where m.seen = false)) as unseenCount
`;
const queryResult = await retry(this.connector._bolt._pool._maxIdle + 1, async () => {
const session = this.connector.session();
try {
const res = await session.run(cypherGetVisitors, { id });
session.close();
return res;
} catch (neo4jError) {
throw new Error(neo4jError);
}
});
const row = queryResult.records[0];
const nodes = {
youVisited: row.get('youVisited').map((yv, index) => Object.assign(
yv.properties,
{ created_at: row.get('yvr')[index].properties.created_at },
)),
visitedYou: row.get('visitedYou').map((vy, index) => Object.assign(
vy.properties,
{ created_at: row.get('vyr')[index].properties.created_at },
)),
unseenCount: row.get('unseenCount'),
};
const youVisitedPromises = nodes.youVisited.map(yv => usersIndex.getObject(yv.user_id));
const visitedYouPromises = nodes.visitedYou.map(vy => usersIndex.getObject(vy.user_id));
let [youVisited, visitedYou] = await Promise.all([
youVisitedPromises, visitedYouPromises,
].map(Promise.all, Promise));
youVisited = youVisited.map(yv => Object.assign(
yv,
{ visited_at: _.get(_.find(nodes.youVisited, { user_id: yv.objectID }), 'created_at') },
));
visitedYou = visitedYou.map(vy => Object.assign(
vy,
{ visited_at: _.get(_.find(nodes.visitedYou, { user_id: vy.objectID }), 'created_at') },
));
result = {
youVisited,
visitedYou,
unseenCount: nodes.unseenCount,
};
最佳答案
看起来您已经有了一个有效的解决方案(使用 COLLECT() 以及您想要的值的新映射)。
如果您确实需要所有值以及更多值,则可以使用 3.1 map projection功能,它可以更轻松地包含节点的部分或全部属性以及您希望在返回的结构中出现的其他属性。
使用查询片段的示例:
OPTIONAL MATCH(you)-[yvr:VISIT]->(youVisited:User)
WITH you, collect(youVisited {.*, created_at: yvr.created_at}) as youVisted
在本例中,.* 表示包含节点 (youVisited) 的所有属性,但如果您只需要某些属性,则可以仅包含相关键,并且键/值对将包含在返回的映射中。因此,如果您只需要 user_id 和created_at,则可以使用以下方法:
OPTIONAL MATCH(you)-[yvr:VISIT]->(youVisited:User)
WITH you, collect(youVisited {.user_id, created_at: yvr.created_at}) as youVisted
关于javascript - Neo4j - 我有 2 个数据相关的收集。我如何将它们合并在一起?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41639613/
我已经在 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(*) 但我收到以
我是一名优秀的程序员,十分优秀!