Neo4J 子查询相同 属性 来计算比率

Neo4J Subquery over same property to calculate ratio

我正在处理推文图表。我正在尝试获取西班牙语推文和英语推文之间的比率。

按语言检查推文数量时:

MATCH (twtEs:Tweet)<-[:HAS_WRITEN]-()-[:HAS_AS_PROFILE_LANGUAGE]->(l:Language)
RETURN DISTINCT l.languageCode, count(*)
\ Result:
╒════════════════╤══════════╕
│"l.languageCode"│"count(*)"│
╞════════════════╪══════════╡
│"en"            │165392    │
├────────────────┼──────────┤
│"es"            │73693     │
└────────────────┴──────────┘

我们可以看到每种语言的计数。

但是当试图直接计算比率时:

MATCH (twtEs:Tweet)<-[:HAS_WRITEN]-()-[:HAS_AS_PROFILE_LANGUAGE]->(:Language{languageCode:'es'})
WITH count(twtEs) AS tweetsEs 
MATCH (twtEn:Tweet)<-[:HAS_WRITEN]-()-[:HAS_AS_PROFILE_LANGUAGE]->(:Language{languageCode:'en'})
WITH count(twtEn) as tweetsEn, tweetsEs
RETURN tweetsEs/tweetsEn as RatioTweetsEsvsEn;
\ Result:
╒═══════════════════╕
│"RatioTweetsEsvsEn"│
╞═══════════════════╡
│0                  │
└───────────────────┘

这就是我得到的,当它应该是 0,44557 时。 我一直在检查 Whosebug 中的文档和其他答案,但没有找到类似于示例的东西。可能第二个查询不正确,但我正在努力解决它。

提前致谢。

我是 运行:

这是因为计数值是整数。

例如:

WITH 165392 AS v1, 73693 AS v2
RETURN v1/v2

╒═══════╕
│"v1/v2"│
╞═══════╡
│2      │
└───────┘

您可以将它们转换为浮点数:

WITH 165392 AS v1, 73693 AS v2
RETURN v1*1.0f/v2*1.0f

╒══════════════════╕
│"v1*1.0f/v2*1.0f" │
╞══════════════════╡
│2.2443379968246644│
└──────────────────┘

哪个会给你:

MATCH (twtEs:Tweet)<-[:HAS_WRITEN]-()-[:HAS_AS_PROFILE_LANGUAGE]->(:Language{languageCode:'es'})
WITH count(twtEs) AS tweetsEs 
MATCH (twtEn:Tweet)<-[:HAS_WRITEN]-()-[:HAS_AS_PROFILE_LANGUAGE]->(:Language{languageCode:'en'})
WITH count(twtEn) as tweetsEn, tweetsEs
RETURN tweetsEs*1.0f/tweetsEn*1.0f as RatioTweetsEsvsEn;