嘿,这是我使用的SQL语句
$sql = "SELECT number, COUNT(name) FROM people WHERE id='$id' GROUP BY number";
$result = mysql_query($sql);
while($row = mysql_fetch_array($result)){
$statarray['stat'.$i] = $row['COUNT(name)'];
$i++; }
number列针对每个名称存储0、1、2或3,因此数组返回的结果是每个数字对应的名称总数。
唯一的问题是,如果所有的名字都存储了一个数字1,我的数组条目'stat0'不会告诉我有多少0,因为它被1的数量所取代(这是因为数组中没有0,所以第一个输出是1).
我如何找出有多少名字在他们的数字列中有0、15、15和3,包括当没有的时候?
SELECT numbers.number ,
COUNT(name)
FROM ( SELECT 0 AS number
UNION ALL
SELECT 1
UNION ALL
SELECT 2
UNION ALL
SELECT 3
) numbers
LEFT JOIN people ON people.number = numbers.number AND id='$id'
GROUP BY numbers.number
或者如果你有一个永久的数字表,如注释
SELECT numbers.number ,
COUNT(name)
FROM numbers
LEFT JOIN people ON people.number = numbers.number
AND id = '$id'
WHERE numbers.number BETWEEN 0 AND 3
GROUP BY numbers.number