想象一下,我有这样的表:

<强> ID:产品:shop_id

1:篮球:41

2:足球:41

3:火箭:45

4:汽车:86

5:平面:86

现在,这是一个大型互联网商城的例子,那里有商店向一个顾客销售,因此顾客可以从每个商店中选择更多产品并在一个购物篮中购买。

但是,我不确定是否有任何SQL语法允许我只是在客户购物篮中获得独特的shop_ids和这些商店的产品总数。所以我会得到类似的东西:

Shop 41有2件商品

购买45件产品

Shop 86两个产品

我可以通过表格进行SQL查询以制作某种['shop_id'] ['number_of_products']数组变量,该变量将存储所有产品的shop_id,然后“将它们唯一”。 - 计算我还有多少次删除一个shop_id以剩下一些但是这看起来像是一些无用的脚本。

如果你有一些不错的想法,请告诉我。

有帮助吗?

解决方案

这正是聚合函数的用途。您为表中的每组行创建一行输出。按shop_id对它们进行分组,并计算每组中的行数。

select shop_id, count(1) from TABLE_NAME
  group by shop_id
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top