0

我有以下数据库结构:

car
+----------+------------+----------------+-----------------+
| car_id   | car_name   | car_model_id   | car_factory_id  |
+----------+------------+----------------+-----------------+

car_model
+---------------+----------------+
| car_model_id  | car_model_name |
+---------------+----------------+

factory
+-------------+---------------+-------------------+
| factory_id  | factory_name  | factory_location  |
+-------------+---------------+-------------------+

factory_location
+----------------------+------------------------+
| factory_location_id  | factory_location_name  |
+----------------------+------------------------+


我想:

  • 列出所有工厂
  • 计算每个工厂生产的汽车数量
  • 按 car_model 分组


输出应该是这样的:

| factory_id | car_model_id = 1 | car_model_id = 2 | car_model_id = ... |
+------------+------------------+------------------+--------------------+
| 1          |        145       |       3307       |         ...        |
+------------+------------------+------------------+--------------------+
| 2          |       32798      |        345       |         ...        |
+------------+------------------+------------------+--------------------+
| 3          |         0        |        10        |         ...        |
+------------+------------------+------------------+--------------------+
| ...        |        ...       |        ...       |         ...        |
+------------+------------------+------------------+--------------------+


我最接近的尝试是这个请求,但这仍然不是我想要的:
SELECT COUNT(car_id) FROM car GROUP BY car_factory_id AND car_model_id

我的 RDBMS 是 MySQL 5.1。

谢谢你的帮助 :)

4

2 回答 2

1

您通常不能通过 rows 的值参数化列数,使用 sql 数据库查询您想要的内容的惯用方法是获得如下内容:

factory_id | car_model_id | count
1          | 1            | 145
1          | 2            | 3307
...
4          | 1            | 3245
4          | 2            | 38

在这种情况下,你会这样做:

SELECT factory_id, car_model_id, COUNT(*) FROM factory
INNER JOIN car ON factory_id = car_factory_id GROUP BY factory_id, car_model_id
于 2012-12-18T13:46:28.980 回答
1

试试这个, ;)

SELECT  a.factory_name , c.car_model_name,
        COUNT(b.car_factory_id) totalCount
FROM    factory a
        LEFT JOIN car b
            ON a.factory_id = b.car_factory_id
        LEFT JOIN car_model c
            ON b.car_model_id = c.car_model_id
GROUP BY a.factory_name , c.car_model_name
ORDER BY factory_name ASC
于 2012-12-18T15:35:10.440 回答