Mysql表格操作——Group By

Group by(查询时或者插入数据时以什么属性作为参照进行分类) 

先来看库中所存数据

mysql> select * from student;
+-----------+-------+------+------+-------+
| Sno       | Sname | Ssex | Sage | Sdept |
+-----------+-------+------+------+-------+
| 201215121 | 李勇  | 男   |   20 | CS    |
| 201215122 | 刘晨  | 女   |   19 | CS    |
| 201215123 | 王敏  | 女   |   18 | MA    |
| 201215124 | 张立  | 男   |   19 | IS    |
+-----------+-------+------+------+-------+

第一种建表方法:

mysql> insert into Dept_age(Sdept,Avg_age)
    -> Select Sdept,AVG(Sage)
    -> From Student
    -> Group by Sdept;
Query OK, 3 rows affected (0.01 sec)
Records: 3  Duplicates: 0  Warnings: 0

查看表格内容:

mysql> select * from dept_age;
+-------+---------+
| Sdept | Avg_age |
+-------+---------+
| CS    |      20 |
| MA    |      18 |
| IS    |      19 |
+-------+---------+

可以发现这一次的平均年龄是按照院系名进行求解的。

假如根据去掉Group by Sdept,按照如下方式建表,

mysql> insert into dept_age(Sdept,avg_age)
    -> select sdept,avg(sage)
    -> from student
    -> ;
Query OK, 1 row affected (0.00 sec)
Records: 1  Duplicates: 0  Warnings: 0

所求的内容就变成了

mysql> select * from dept_age;
+-------+---------+
| Sdept | Avg_age |
+-------+---------+
| CS    |      19 |
+-------+---------+
1 row in set (0.00 sec)

SQL自动将所有的内容进行了求和后取平均值,未考虑院系的问题。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

牛哥带你学代码

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值