SQL查询计数有条件
我第一次使用SQL查询并学习。 我有这样的桌子:
juestname | productCompanyID |
---|---|
2001 | ID 1 |
2001 | ID 1 |
2001 | ID 2 |
2001 | ID 1 |
2001 | ID 1 2002 ID 1 |
2002 | ID 1 |
2002 | ID 1 |
2002 ID 2 2002 | ID 2 |
2002 | ID 2 |
2003 | ID 2 |
,我想计算多少次产品companyid出现,但仅计算一次。 (对不起,我的英语不是我的语言,我可能不清楚)
意思是我写了这个SQL:
SELECT DISTINCT(productcompanyid),
COUNT(productcompanyid)
FROM mydatabase
GROUP BY productcompanyid
这给了我ID 1:6和ID 2:4。
我的意思是,我的 拥有ID 1:2(在2001年和2002年至少看来一次)和ID 2:3(由于2001年,2002年和2003年至少看来一次)
感谢您的帮助。
I'm using SQL Queries for the first time and learning it.
I've got a table like this:
yearName | productcompanyID |
---|---|
2001 | ID 1 |
2001 | ID 1 |
2001 | ID 2 |
2001 | ID 1 |
2001 | ID 1 |
2002 | ID 1 |
2002 | ID 1 |
2002 | ID 2 |
2002 | ID 2 |
2003 | ID 2 |
And I would like to count how many times a productcompanyID appear but counting it only once for a year. (Sorry my English is not my language and I might not be clear)
What I mean, for the moment I've writtent this SQL:
SELECT DISTINCT(productcompanyid),
COUNT(productcompanyid)
FROM mydatabase
GROUP BY productcompanyid
And it gives me the result as ID 1: 6 and ID 2 : 4.
What I would like to have is ID 1 : 2 (as it appears at least once in year 2001 and year 2002) and ID 2: 3 (as it appears at least once in year 2001, year 2002 and year 2003)
Thanks for your help.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
实际上,您需要结合数量和截然不同的东西,类似的东西:
You actually need to combine count and distinct, something like this:
最简单的查询和一些额外的性能是使用2级聚合,例如:
它应该给出您对问题的要求。
The simplest query and have some additional performance are using 2 level aggregation, eg:
It should give the result as what you asking on the question.