使用mysql的disctinct group by查詢不重復(fù)記錄
更新時(shí)間:2008年08月01日 00:15:40 作者:
非常不錯(cuò)的方法,用mysql的group by解決不重復(fù)記錄的問(wèn)題,看來(lái)我需要學(xué)習(xí)的地方太多了
有個(gè)需求,一直沒(méi)有解決,在google上找了半天,給出的方案沒(méi)有一個(gè)能用了,最后鬼使神差搞定了。
是這樣的,假設(shè)一個(gè)表:
id f_id value
1 2 a
2 2 b
3 5 c
4 9 c
5 9 a
6 6 d
id f_id value
1 2 a
2 2 b
3 5 c
4 9 c
5 9 a
6 6 d
id是主鍵,f_id是外鍵,我需要獲得不重復(fù)的外鍵f_id的數(shù)據(jù),如果用group by 或者distinct很容易搞定
select f_id from table group by f_id
select distinct f_id from table
但如果再想在結(jié)果中得到id值的話,不管怎么都會(huì)亂。比如我想在結(jié)果中用id進(jìn)行排序,諸如”select distinct f_id, id from table order by id desc”完全白費(fèi)。在google上看了大量的例子,發(fā)現(xiàn)需要在select中對(duì)id做手腳,讓mysql知道除了f_id外,對(duì)id應(yīng)該進(jìn)行如何的操作。諸如Max, Min, Avg,Sun..都是可以的,于是變成以下的代碼就搞定了……
select f_id, max(id) as id from table group by f_id order by id desc
搞定,網(wǎng)上有個(gè)文章很接近答案,但是他沒(méi)有”as id”,導(dǎo)致在我的mysql中執(zhí)行結(jié)果有誤,呵呵。
是這樣的,假設(shè)一個(gè)表:
id f_id value
1 2 a
2 2 b
3 5 c
4 9 c
5 9 a
6 6 d
id f_id value
1 2 a
2 2 b
3 5 c
4 9 c
5 9 a
6 6 d
id是主鍵,f_id是外鍵,我需要獲得不重復(fù)的外鍵f_id的數(shù)據(jù),如果用group by 或者distinct很容易搞定
select f_id from table group by f_id
select distinct f_id from table
但如果再想在結(jié)果中得到id值的話,不管怎么都會(huì)亂。比如我想在結(jié)果中用id進(jìn)行排序,諸如”select distinct f_id, id from table order by id desc”完全白費(fèi)。在google上看了大量的例子,發(fā)現(xiàn)需要在select中對(duì)id做手腳,讓mysql知道除了f_id外,對(duì)id應(yīng)該進(jìn)行如何的操作。諸如Max, Min, Avg,Sun..都是可以的,于是變成以下的代碼就搞定了……
select f_id, max(id) as id from table group by f_id order by id desc
搞定,網(wǎng)上有個(gè)文章很接近答案,但是他沒(méi)有”as id”,導(dǎo)致在我的mysql中執(zhí)行結(jié)果有誤,呵呵。
相關(guān)文章
MYSQL數(shù)據(jù)庫(kù)使用UTF-8中文編碼亂碼的解決辦法
這篇文章主要介紹了MYSQL數(shù)據(jù)庫(kù)使用UTF-8中文編碼亂碼的解決辦法,需要的朋友可以參考下2015-10-10Mysql分組排序取每組第一條的2種實(shí)現(xiàn)方式
開(kāi)發(fā)中經(jīng)常會(huì)遇到,分組查詢最新數(shù)據(jù)的問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于Mysql分組排序取每組第一條的2種實(shí)現(xiàn)方式,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02MySQL存儲(chǔ)結(jié)構(gòu)用法案例分析
這篇文章主要介紹了MySQL存儲(chǔ)結(jié)構(gòu)用法,結(jié)合具體案例形式分析了mysql存儲(chǔ)結(jié)構(gòu)相關(guān)使用方法與操作注意事項(xiàng),需要的朋友可以參考下2018-07-07mysql中使用replace替換某字段的部分內(nèi)容
這篇文章主要介紹了mysql中使用replace替換某字段的部分內(nèi)容的方法,需要的朋友可以參考下2014-11-11