0

私はこのようなテーブルを持っています:

| ID | 名前| カテゴリ|

特定のカテゴリのセットの行をカウントしたいのですが、カテゴリの配列があり、各カテゴリの行数を知りたいのですが、私が行ったことは次のとおりです。

$cats = array(2,4,5,1,8,44,47);
foreach($cats as $cat){
  $res = mysql_fetch_assoc(mysql_quer('select count(ID) from item where CATEGORY='.$cat);
}

私もやってみました'select count(ID) from item where CATEGORY IN ('.implode(',',$cat).')'

しかし、これは私に合計数を与えます。
ループせずにカテゴリごとのカウントを取得する方法はありますか?SQLを使用します。
私のSGBDはMySQLです

4

2 に答える 2

5
select count(ID), category 
from item 
     where 
       CATEGORY IN ('.implode(',',$cat).') 
group by category
于 2012-07-09T07:39:15.343 に答える
2

このSQLを試してください:

SELECT count(ID) FROM item WHERE category IN (...) GROUP BY category

コード:

$cats = array(2,4,5,1,8,44,47);
$ret = mysql_query('SELECT category, count(ID) as count FROM item WHERE category IN ('.join(',', $cats).') GROUP BY category');
if (!$ret) {
  die(mysql_error());
}
$results = array();
while($row = mysql_fetch_assoc($ret)) {
  $results[$row['category']] = $row['count'];
}
var_dump($results);
于 2012-07-09T07:39:37.443 に答える