mysql中distinct的學(xué)習(xí)

背景

今年給自己定下的基調(diào)就是要好好學(xué)一下數(shù)據(jù)庫相關(guān)的知識,所以今天也開始棄用各類ORM框架箕宙,使用原生的sql來干一些活嚎朽。這次遇到的問題就是一個去重查詢的問題。

過程

去重查詢柬帕,我第一個想到的就是group by哟忍。這個方法是可以去重的。

SELECT count(tag_id) FROM xx.xx GROUP BY tag_id;

結(jié)果看到的數(shù)據(jù)是每一個不同的tag_id的計數(shù)陷寝。類似下面這樣的數(shù)據(jù):

count(tag_id)
1
1
1
1
4
1
6

這樣的數(shù)據(jù)顯然不是我需要的锅很,我要的數(shù)據(jù)是統(tǒng)計不同類型的tag_id有多少個,而不是每種tag_id有多少條記錄凤跑。

經(jīng)過搜索發(fā)現(xiàn)爆安,distinct能滿足我的要求。上面的sql改為:

SELECT count(distinct tag_id) FROM xx.xx GROUP BY tag_id;

這樣的查詢結(jié)果就是我想要的仔引。

后續(xù)

問題雖然是解決了扔仓,但是抱著學(xué)習(xí)的心態(tài)褐奥,看了一下distinct相關(guān)的內(nèi)容。

distinct翻譯過來就是 不同的 類似的意思当辐。

我是把它跟聚合函數(shù)count放在一起使用了抖僵,如果單獨(dú)使用,其實(shí)就是去重的結(jié)果缘揪。

如果不使用count來統(tǒng)計總數(shù)耍群,直接使用distinct,這個結(jié)果與group by都是去重的記錄找筝。區(qū)別就是排序不一樣蹈垢。group by會執(zhí)行排序,而distinct不會執(zhí)行排序袖裕。

如果查詢的結(jié)果帶上limit子句的話曹抬,distinctgroup by都會返回對應(yīng)的limit數(shù)量,不過group by的結(jié)果也是排序后的結(jié)果急鳄。

性能

distinctgroup by功能類似谤民。我查了一下資料。

DISTINCT:這種方式會將全部內(nèi)容存儲在一個hash結(jié)構(gòu)里疾宏,最后通過計算hash結(jié)構(gòu)中key的個數(shù)即可得到結(jié)果张足,典型的以空間換取時間的方式。
GROUP BY:這種方式是先將字段排序(一般使用sort)坎藐,然后進(jìn)行計數(shù)为牍,典型的以時間換取空間。

根據(jù)這個說法岩馍,數(shù)據(jù)離散程度越大碉咆,用group by的方式就更高效,反之則是distinct更高效蛀恩。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末疫铜,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子赦肋,更是在濱河造成了極大的恐慌块攒,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,104評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件佃乘,死亡現(xiàn)場離奇詭異囱井,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)趣避,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評論 3 399
  • 文/潘曉璐 我一進(jìn)店門庞呕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事住练〉貑” “怎么了?”我有些...
    開封第一講書人閱讀 168,697評論 0 360
  • 文/不壞的土叔 我叫張陵讲逛,是天一觀的道長亏吝。 經(jīng)常有香客問我,道長盏混,這世上最難降的妖魔是什么蔚鸥? 我笑而不...
    開封第一講書人閱讀 59,836評論 1 298
  • 正文 為了忘掉前任,我火速辦了婚禮许赃,結(jié)果婚禮上止喷,老公的妹妹穿的比我還像新娘。我一直安慰自己混聊,他們只是感情好弹谁,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,851評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著句喜,像睡著了一般预愤。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上咳胃,一...
    開封第一講書人閱讀 52,441評論 1 310
  • 那天鳖粟,我揣著相機(jī)與錄音,去河邊找鬼拙绊。 笑死,一個胖子當(dāng)著我的面吹牛泳秀,可吹牛的內(nèi)容都是我干的标沪。 我是一名探鬼主播,決...
    沈念sama閱讀 40,992評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼嗜傅,長吁一口氣:“原來是場噩夢啊……” “哼金句!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起吕嘀,我...
    開封第一講書人閱讀 39,899評論 0 276
  • 序言:老撾萬榮一對情侶失蹤违寞,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后偶房,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體趁曼,經(jīng)...
    沈念sama閱讀 46,457評論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,529評論 3 341
  • 正文 我和宋清朗相戀三年棕洋,在試婚紗的時候發(fā)現(xiàn)自己被綠了挡闰。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,664評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖摄悯,靈堂內(nèi)的尸體忽然破棺而出赞季,到底是詐尸還是另有隱情,我是刑警寧澤奢驯,帶...
    沈念sama閱讀 36,346評論 5 350
  • 正文 年R本政府宣布申钩,位于F島的核電站,受9級特大地震影響瘪阁,放射性物質(zhì)發(fā)生泄漏撒遣。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,025評論 3 334
  • 文/蒙蒙 一罗洗、第九天 我趴在偏房一處隱蔽的房頂上張望愉舔。 院中可真熱鬧,春花似錦伙菜、人聲如沸轩缤。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,511評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽火的。三九已至,卻和暖如春淑倾,著一層夾襖步出監(jiān)牢的瞬間馏鹤,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,611評論 1 272
  • 我被黑心中介騙來泰國打工娇哆, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留湃累,地道東北人。 一個月前我還...
    沈念sama閱讀 49,081評論 3 377
  • 正文 我出身青樓碍讨,卻偏偏與公主長得像治力,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子勃黍,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,675評論 2 359

推薦閱讀更多精彩內(nèi)容