Mysql与Oracle group by的不同之处

在Oracle里,分组与聚合必须是成对出现的,”非分组的字段“必须做聚合操作,否则执行就会报错。而在Mysql里则完全不同。

mysql> select actor.actor_id,actor.first_name from actor join actor_info on (actor.actor_id=actor_info.actor_id) group by actor.first_name;

+----------+-------------+
| actor_id | first_name  |
+----------+-------------+
|       71 | ADAM        |
|      165 | AL          |
|      173 | ALAN        |
|      125 | ALBERT      |
|       29 | ALEC        |
|       65 | ANGELA      |
|       76 | ANGELINA    |
|       49 | ANNE        |
|       34 | AUDREY      |
|      196 | BELA        |
|       83 | BEN         |
|        6 | BETTE       |
select actor.first_name,count(actor.actor_id) from actor join actor_info on (actor.actor_id=actor_info.actor_id) group by actor.first_name;

+-------------+----------+
| first_name  | count(*) |
+-------------+----------+
| ADAM        |        2 |
| AL          |        1 |
| ALAN        |        1 |
| ALBERT      |        2 |
| ALEC        |        1 |
| ANGELA      |        2 |
| ANGELINA    |        1 |
| ANNE        |        1 |
| AUDREY      |        2 |
| BELA        |        1 |
| BEN         |        2 |
其中,actor_id未作聚合,却能输出值,当某个first_name的分组记录数大于1的时候, mysql将会输出该分组第一条记录

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值