gpt4 book ai didi

多层次营销的 Neo4j 数据库建模

转载 作者:行者123 更新时间:2023-12-03 23:53:04 25 4
gpt4 key购买 nike

我正在尝试为 neo4j 数据库建模图形数据库。以下是详细信息:

代理商 - 产品 - 等级 - 佣金。

会有代理。
会有产品(比如保健品)。

一个代理将加入另一个代理或可以直接加入。
一个代理只能有一个父级,但可以有多个子级。
在其他代理下加入代理的广度和深度没有限制。

代理商将被提升,排名取决于他们购买的产品的总值(value)。
代理商按月获得佣金,这取决于他们和他们的 child 在一个月内购买的产品的总值(value)。

Node : Agent { name, age, ..., rank } A1, A2, A3...

Node : Product { name, description, ..., price } P1, P2, P3...

Relationship : purchases { date, time, quantity, total pay }

( Agent ) -[:purchases]-> ( Product )



代理可以一次购买多个产品。
代理可以多次购买同一产品。

例子 :

A1{ 'John Doe', '34', ..., '4' }

P1{ 'Px1', 'desx1', ..., '$2.3' }

A1 -[ :purchases { 03-01-2014, 09.30, 02, '$4.6' } ]-> ( P1 )

A1 -[ :purchases { 07-01-2014, 13.45, 01, '$2.3' } ]-> ( P1 )



?这就是我被困的地方。所以,在这里我需要创建一个关系 [:purchases]
每次代理购买一个产品,即使它是相同的产品?

在这种情况下,相同的两个节点之间具有相同类型和标签的多重关系是否有效?因为代理商可能会经常频繁地购买相同的产品,这会造成更大的数量。相同节点之间的多个关系。

该模型是否遵循标准建模原则?
任何人都可以建议更好的建模或更正吗?

最佳答案

正如 Stefan 建议的那样,我会介绍 Purchase与产品有关系并在该节点中存储购买值(value)的节点。这样您就可以将查询限制在购买范围内,而无需深入了解产品。

(:Agent)-[:made]->(:Purchase {date: XXX, value: XXX})-[:HAS]->(:Product)

假设我们有关系 :WORKS_FOR将 child 代理人与其 parent 联系起来:
(a1:Agent)-[:WORKS_FOR]->(a2:Agent)

这个简单的查询将为您提供每个代理自己完成的购买总额,不考虑他/她的 child :
MATCH (parent:Agent)-[:MADE]->(p:Purchase) RETURN parent.name, sum(p.value)

现在,如果您还想考虑代理 child 的购买,您可以执行以下操作:
MATCH (parent:Agent)-[:MADE]->(p:Purchase) WITH parent, sum(p.value) AS own_value OPTIONAL MATCH (parent)<-[:WORKS_FOR*]-(child:Agent)-[:MADE]->(pc:Purchase) RETURN parent.name, own_value + sum(pc.value) as total_value

关于多层次营销的 Neo4j 数据库建模,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24465550/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com