课程表

Impala 基础

Table 特定语句

Impala 子句

工具箱
速查手册

impala GROUP BY子句

当前位置:免费教程 » 大数据/云 » Impala

Impala GROUP BY子句与SELECT语句协作使用,以将相同的数据排列到组中。

语法

以下是GROUP BY子句的语法。

  1. select data from table_name Group BY col_name;

假设我们在数据库my_db中有一个名为customers的表,其内容如下 -

  1. [quickstart.cloudera:21000] > select * from customers;
  2. Query: select * from customers
  3. +----+----------+-----+-----------+--------+
  4. | id | name | age | address | salary |
  5. +----+----------+-----+-----------+--------+
  6. | 1 | Ramesh | 32 | Ahmedabad | 20000 |
  7. | 2 | Khilan | 25 | Delhi | 15000 |
  8. | 3 | kaushik | 23 | Kota | 30000 |
  9. | 4 | Chaitali | 25 | Mumbai | 35000 |
  10. | 5 | Hardik | 27 | Bhopal | 40000 |
  11. | 6 | Komal | 22 | MP | 32000 |
  12. +----+----------+-----+-----------+--------+
  13. Fetched 6 row(s) in 0.51s

您可以使用GROUP BY查询获得每个客户的工资总额,如下所示。

  1. [quickstart.cloudera:21000] > Select name, sum(salary) from customers Group BY name;

执行时,上述查询给出以下输出。

  1. Query: select name, sum(salary) from customers Group BY name
  2. +----------+-------------+
  3. | name | sum(salary) |
  4. +----------+-------------+
  5. | Ramesh | 20000 |
  6. | Komal | 32000 |
  7. | Hardik | 40000 |
  8. | Khilan | 15000 |
  9. | Chaitali | 35000 |
  10. | kaushik | 30000 |
  11. +----------+-------------+
  12. Fetched 6 row(s) in 1.75s

假设此表有多个记录,如下所示。

  1. +----+----------+-----+-----------+--------+
  2. | id | name | age | address | salary |
  3. +----+----------+-----+-----------+--------+
  4. | 1 | Ramesh | 32 | Ahmedabad | 20000 |
  5. | 2 | Ramesh | 32 | Ahmedabad | 1000| |
  6. | 3 | Khilan | 25 | Delhi | 15000 |
  7. | 4 | kaushik | 23 | Kota | 30000 |
  8. | 5 | Chaitali | 25 | Mumbai | 35000 |
  9. | 6 | Chaitali | 25 | Mumbai | 2000 |
  10. | 7 | Hardik | 27 | Bhopal | 40000 |
  11. | 8 | Komal | 22 | MP | 32000 |
  12. +----+----------+-----+-----------+--------+

现在,您可以使用Group By子句,如下所示,考虑重复的记录条目,获取员工的总工资。

  1. Select name, sum(salary) from customers Group BY name;

执行时,上述查询给出以下输出。

  1. Query: select name, sum(salary) from customers Group BY name
  2. +----------+-------------+
  3. | name | sum(salary) |
  4. +----------+-------------+
  5. | Ramesh | 21000 |
  6. | Komal | 32000 |
  7. | Hardik | 40000 |
  8. | Khilan | 15000 |
  9. | Chaitali | 37000 |
  10. | kaushik | 30000 |
  11. +----------+-------------+
  12. Fetched 6 row(s) in 1.75s
转载本站内容时,请务必注明来自W3xue,违者必究。
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号