本帖最后由 myskya 于 2019-12-9 11:28 编辑 ) M0 W& |- x3 P. X
问题描述+ C6 a7 o) d; O( r
查询数据经常需要对数据表的某一属性进行去重操作,group by 和 distinct 都有去重功能,但是有区别。 $ w3 e: i2 C5 |: h. C
1.数据去重样例样例数据表 quancheng_test - f S* _3 x, I4 [* J2 l9 l
1 t8 N; T \# X* O" J功能需求:按 name 进行去重,把 id 查出来。/ t& B' J5 S& b" R! R$ k' ^
方案1: - select id from table group by name;
复制代码结果1: ' W4 G# [8 D5 j3 S6 q3 W5 i+ |
' d* P B/ y( r: O
方案2: - select id, count(distinct name) from quancheng_test group by name;
复制代码结果2: . S, Z( z, I! c! R, J
# d+ {+ k" ` N% D8 s
2.两种去重方案的区别group 是按组查询的,是一种聚合查询,很多时候是为了做统计用,例如:
( ]- w+ I6 q% G+ Z% Q' |, O. e! G对 name 分组,并统计每组 id 的和, - select sum(id), name from quancheng_test group by name;
复制代码查询结果为: * z% F* B; W: y5 k% u- C
7 Q+ `4 H |2 Z. ~distinct 是查询出来以后再把重复的去掉# ]3 o. H5 U# ^
性能上 group 比 distinct 要好很多 - A5 L) ]( x, r. L$ S* z% F
' L- Z$ S& a* b. W7 p/ [3 i
|