假设,现在有这么一个表格:
id name value
1 a 123
1 a 231
2 a 123
2 b 321
我现在想要达到的效果是,对 id 和 name 去重。
Output:
1 a 123 or 1 a 231 2 a 123 2 b 321
请问下,这个该怎么实现呢? Distinct 我没有实现,Group By 也是。
1
talen666 2018 年 9 月 13 日
别想着一个 SQL 解决,步子迈大了容易扯着蛋
|
2
zarte 2018 年 9 月 13 日
Group By id 和 name 不是就会变成 1a 2a 2b 了么?
|
3
zarte 2018 年 9 月 13 日
加个 count(1) as xx
|
4
vindurriel 2018 年 9 月 13 日 via iPhone
select max(value), id, name from TABLE group by id, name;
|
5
reus 2018 年 9 月 13 日
SELECT
DISTINCT ON (id, name) * FROM table ORDER BY value asc/desc 当然,DISTINCT ON 是 PostgreSQL 才有的,不想换的话,可以参考: https://stackoverflow.com/questions/17673457/converting-select-distinct-on-queries-from-postgresql-to-mysql |
6
wqzjk393 2018 年 9 月 13 日
excel、pandas 有单独对某些字段去重的,选 keepfirst 就行。mysql 好像要子查询加 join 才能实现
|
7
F281M6Dh8DXpD1g2 2018 年 9 月 13 日
对 id,name 去重以后你的 value 怎么选?
|
8
whypool 2018 年 9 月 13 日
客户端去重>后端去重
|
9
niaobulashi 2018 年 9 月 13 日
。。。晕,你是依据什么来去重呢,value 没有规则吗
就是单单去重 id 和 name 那么不去重的 value,要么就是 max,要么就是 min 那么答案就是 4 楼了 |
10
wqzjk393 2018 年 9 月 13 日
oracle 是可以用 over 函数,groupby id name,然后对 value 大小排名,根据需求选择排名第 x 的作为唯一的值。mysql 没有这些只能用 max min 了
|