mysql group by 处理方式的异同

本文探讨了MySQL与SQL Server中GROUP BY语句的不同行为。MySQL允许在GROUP BY子句中使用未在SELECT列表中出现的列,而SQL Server则不允许。此外,MySQL即使在SELECT列表中混合使用普通列和聚合函数时也不一定需要GROUP BY。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天突然发现mysql 中group by 的用法比较反常,一些之前sql server中出现的错误也可以执行。上网查了一下资料如下:

在不同的数据库里,对group by 的处理方式有些不太一样,对于sqlserver和mysql来说,group by有以下几点区别:

一、在SQLSERVER中group by 后面的出现的属性列值,应该是select 后面出现的属性列,比如:

select name,count(1)

from users

group by name

而下面这句则会报错:

select name,count(1)

from users

group by id

对于上面这句,在mysql中是可以执行的,我用的版本是Server version: 5.1.49-community MySQL Community Server (GPL)

 

二、在SQLSERVER中,如果select 后跟的属性列表中,同时使用了普通列名和聚合函数,则必须使用group by ,比如

select name,count(1) from users;

这句是要报错的。

而在mysql中这句也可以执行,其结果是将第一行的name取出显示,然后将所有表的数据进行聚合运算输出。举个例子吧:

mysql> select * from t3;
+----+------+---------------------+---------------------+
| id | name | alter_date          | birthday            |
+----+------+---------------------+---------------------+
|  1 | ljf  | 2010-12-24 19:11:24 | 2010-12-22 00:00:00 |
|  2 | ljd  | 2010-12-24 00:00:00 | 2010-12-24 00:00:00 |
|  3 | ldh  | 2010-12-24 00:00:00 | 2010-12-24 00:00:00 |
|  4 | xw   | 2010-12-25 19:21:31 | 2010-12-24 00:00:00 |
+----+------+---------------------+---------------------+
4 rows in set (0.05 sec)

mysql> select name,sum(id) from t3;
+------+---------+
| name | sum(id) |
+------+---------+
| ljf  |      10 |
+------+---------+
1 row in set (0.00 sec)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值