繁体   English   中英

如何在MySQL中对列进行分组并摆脱重复的ID?

[英]How do I group columns in MySQL and get rid of recurring ids?

的MySQL

+-----+-----+
| id1 | id2 |
+-----+-----+
|  1  |  1  |
+-----+-----+
|  1  |  1  |
+-----+-----+
|  1  |  2  |
+-----+-----+
|  2  |  1  |
+-----+-----+

的PHP

$a = mysql_query("SELECT id1, COUNT(id2) AS count FROM table GROUP BY id1");
while($b = mysql_fetch_assoc($a))
{
    echo 'id1: '.$b['id1'].' | count: '.$b['count'].'<br />';
}

输出:

id1: 1 | count: 3
id1: 2 | count: 1

但是,如何删除ID2列中每个ID1的重复编号? 例如, id1为1的计数应为2而不是3,因为我只想对id2中1进行一次计数,而不是两次。

因此,输出实际上应该是:

id1: 1 | count: 2
id1: 2 | count: 1

我希望这是有道理的。

SELECT id1, COUNT(DISTINCT id2) ...

SELECT id1, COUNT(DISTINCT id2) AS count FROM table GROUP BY id1

使用子查询:

SELECT 
  t.id1,COUNT(t.id2) AS count
FROM
  (SELECT DISTINCT id1,id2 FROM table) as t
GROUP BY 
  t.id1

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM