php - MySQL 从按项目分组的表中选择用户列表,按小时数降序列出

标签 php mysql select max

我有一个如下所示的时间表:

CREATE TABLE time
    (`id` int, `hours` float(1), `project` varchar(55), `user` varchar(45));

INSERT INTO time
    (`id`, `hours`, `project`, `user`)
VALUES
    (1, '3.5', 'Project A', 'Bob'),
    (2, '1', 'Project A', 'Anne'),
    (3, '2', 'Project B', 'Anne'),
    (4, '6', 'Project B', 'Anne'),
    (5, '2', 'Project C', 'Joe'),
    (6, '9', 'Project C', 'Joe'),
    (7, '1', 'Project C', 'Sam'),
    (8, '22', 'Project A', 'Bob');

我想返回一个像这样的表格:

th {background-color:#999999}
td {width:200px}
<table>
<thead>
  <tr>
    <th>Project</th>
    <th>User 1 (most hours)</th>
    <th>User 2 (2nd most hours)</th>
    <th>etc....</th>
  </tr>
</thead>

<tr>
  <td>Project A</td>
  <td>Bob</td>
  <td>Anne</td>
</tr>

<tr>
  <td>Project B</td>
  <td>Anne</td>
  <td>null</td>
</tr>

<tr>
  <td>Project C</td>
  <td>Joe</td>
  <td>Sam</td>
</tr>
</table>

如图所示,我需要按降序列出谁在每个项目上花费最多的时间。我相信我需要从子查询中执行 SELECT,但我似乎无法让它正常工作。

最佳答案

尝试这个查询:

SELECT project, user
FROM time
GROUP BY project, user
ORDER BY SUM(hours) DESC

这将根据您问题中的示例数据给出以下结果集:

--------------------
|  project  | user |
--------------------
| Project A | Bob  |
| Project A | Anne |
| Project B | Anne |
| Project C | Joe  |
| Project C | Sam  |
--------------------

请注意,每个用户在每个项目上的总工作时间不会列出,因为您没有要求这样做。

关于php - MySQL 从按项目分组的表中选择用户列表,按小时数降序列出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29025784/

相关文章:

php - MediaWiki 批量页面重命名

mysql - 更新表 - Mysql

MySQL 连接两个潜在的字段名称

mysql - 如何使用插入语句将 unicode 字符插入 mysql?

Python MySQLdb 转换列表数据以从 SELECT 输出 CSV

MySql如何返回包含所有选定功能的所有项目

php - 在 PHP 中处理大数组

javascript - 使用 jquery 添加类到 ajax 表单

php - colname 返回数据库表中的第一个条目,而不是选定的条目

php - SQL 选择具有字符限制的所有列