程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> Mysql與Oraclegroupby的不同之處

Mysql與Oraclegroupby的不同之處

編輯:MySQL綜合教程

Mysql與Oraclegroupby的不同之處


在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將會輸出該分組第一條記錄

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved