当前位置:  开发笔记 > 数据库 > 正文

如何使用SQL计算唯一记录并在表中获取这些唯一身份的数量?

如何解决《如何使用SQL计算唯一记录并在表中获取这些唯一身份的数量?》经验,为你挑选了1个好方法。

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

ID:产品:shop_id

1:篮球:41

2:足球:41

3:火箭:45

4:汽车:86

5:平面:86

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

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

Shop 41有2件商品

购买45件产品

店铺86两个产品

我可以通过表格进行SQL查询来制作某种['shop_id'] ['number_of_products']数组变量,这些变量可以存储所有产品的shop_ids,然后"将它们唯一" - 向上计算我必须切割多少次还有一个shop_id要剩下一些,但这似乎是一些无用的脚本.

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



1> Andru Luvisi..:

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

select shop_id, count(1) from TABLE_NAME
  group by shop_id


不,(1)不是对任何列的引用,它只是整数值1.使用COUNT(*)或COUNT(columnname)更为典型.Glomek使用COUNT(1)作为常量整数值,因为有些人认为这比引用列更快.
推荐阅读
ERIK又
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有