如何在密码查询中创建 GROUP BY?

Haj*_*jer 3 sql group-by neo4j cypher

我想将 SQL 查询转换为密码。请问,是否有任何解决方案可以在密码中创建 GROUP BY?

    SELECT dt.d_year, 
           item.i_brand_id          brand_id, 
           item.i_brand             brand, 
           Sum(ss_ext_discount_amt) sum_agg 
    FROM   date_dim dt, 
   store_sales, 
   item 
    WHERE  dt.d_date_sk = store_sales.ss_sold_date_sk 
    AND store_sales.ss_item_sk = item.i_item_sk 
    AND item.i_manufact_id = 427 
    AND dt.d_moy = 11 
    GROUP  BY dt.d_year, 
      item.i_brand, 
      item.i_brand_id 
   ORDER  BY dt.d_year, 
      sum_agg DESC, 
      brand_id;
Run Code Online (Sandbox Code Playgroud)

Tez*_*zra 9

在 Cypher 中,GROUP BY 由所有聚合函数隐式完成。在 WITH/RETURN 语句中,任何不属于聚合的列都将是 GROUP BY 键。

所以例如在

MATCH (n:Person)
RETURN COUNT(n), n.name, n.age
Run Code Online (Sandbox Code Playgroud)

计数将计算所有具有相同名称和年龄的节点。如果我改为

MATCH (n:Person)
RETURN COUNT(n), n.name, MIN(n.age), MAX(n.age)
Run Code Online (Sandbox Code Playgroud)

我将计算有多少人拥有相同的名字,以及该名字的年龄范围。