使用mysql的disctinct group by查詢不重復(fù)記錄
更新時(shí)間:2008年08月01日 00:15:40 作者:
非常不錯(cuò)的方法,用mysql的group by解決不重復(fù)記錄的問題,看來我需要學(xué)習(xí)的地方太多了
有個(gè)需求,一直沒有解決,在google上找了半天,給出的方案沒有一個(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值的話,不管怎么都會亂。比如我想在結(jié)果中用id進(jìn)行排序,諸如”select distinct f_id, id from table order by id desc”完全白費(fèi)。在google上看了大量的例子,發(fā)現(xiàn)需要在select中對id做手腳,讓mysql知道除了f_id外,對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è)文章很接近答案,但是他沒有”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值的話,不管怎么都會亂。比如我想在結(jié)果中用id進(jìn)行排序,諸如”select distinct f_id, id from table order by id desc”完全白費(fèi)。在google上看了大量的例子,發(fā)現(xiàn)需要在select中對id做手腳,讓mysql知道除了f_id外,對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è)文章很接近答案,但是他沒有”as id”,導(dǎo)致在我的mysql中執(zhí)行結(jié)果有誤,呵呵。
相關(guān)文章
Mysql數(shù)據(jù)庫表定期備份的實(shí)現(xiàn)詳解
這篇文章主要介紹了Mysql數(shù)據(jù)庫表定期備份的實(shí)現(xiàn)詳解的相關(guān)資料,需要的朋友可以參考下2017-03-03
navicat連接Mysql數(shù)據(jù)庫報(bào)2013錯(cuò)誤解決辦法
這篇文章主要介紹了navicat連接Mysql數(shù)據(jù)庫報(bào)2013錯(cuò)誤的解決辦法,首先檢查MySQL是否安裝成功,然后修改配置文件,添加或注釋掉特定行,最后連接進(jìn)入MySQL服務(wù)并執(zhí)行授權(quán)命令,需要的朋友可以參考下2025-02-02
一鍵搭建MYSQL主從,輕松應(yīng)對數(shù)據(jù)備份與恢復(fù)
MYSQL主從是一種常見的數(shù)據(jù)庫架構(gòu),它可以提高數(shù)據(jù)庫的可用性和性能,在主從架構(gòu)中,主數(shù)據(jù)庫負(fù)責(zé)處理寫操作,而從數(shù)據(jù)庫負(fù)責(zé)處理讀操作,當(dāng)主數(shù)據(jù)庫發(fā)生故障時(shí),從數(shù)據(jù)庫可以接管并繼續(xù)提供服務(wù),從而實(shí)現(xiàn)高可用性,需要的朋友可以參考下2023-10-10
Mysql誤操作后利用binlog2sql快速回滾的方法詳解
相信每個(gè)和數(shù)據(jù)庫打交道的程序員都會碰一個(gè)問題,MySQL誤操作后如何快速回滾?那么下面這篇文章主要給大家介紹了關(guān)于Mysql誤操作后利用binlog2sql快速回滾的相關(guān)資料,文中介紹的非常詳細(xì),需要的朋友可以參考下。2017-07-07
centos 7系統(tǒng)下編譯安裝 mysql5.7教程
因?yàn)镸ysql5.7的更新特性還是非常多,所以這篇文章就給大家介紹以下在centos上面編譯安裝mysql5.7的教程。本文給大家介紹的步驟還是相對來說比較詳細(xì)的,相信對大家具有一定的參考借鑒價(jià)值,有需要的朋友們可以參考借鑒,下面來一起看看吧。2016-11-11
windows下mysql 8.0.13 解壓版安裝圖文教程
這篇文章主要為大家詳細(xì)介紹了windows下mysql 8.0.13 解壓版安裝圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-02-02

