今天有個(gè)需求,有2張表:
1、一個(gè)“搜索記錄”表search,一個(gè)“搜索后下載記錄”表down
2、映射關(guān)系:每一個(gè)下載記錄對應(yīng)一條搜索記錄,
????????????????????????? 第個(gè)搜索記錄對應(yīng)一條下載記錄,也可能沒有下載記錄
現(xiàn)在需要統(tǒng)計(jì)某個(gè)搜索詞的搜索次數(shù)、下載次數(shù) 和 未下載次數(shù)
正常情況下需要統(tǒng)計(jì)3次:
SELECT COUNT(*) as 搜索次數(shù) FROM search WHERE keyword='key';
SELECT COUNT(*) as 下載次數(shù) FROM down WHERE keyword='key';
SELECT COUNT(*) as 未下載次數(shù)
? FROM search a LEFT JOIN down b ON a.keyword=b.keyword
?WHERE a.keyword='key' AND?b.keyword IS NULL;
通過查詢MSDN和相關(guān)試驗(yàn)后,發(fā)現(xiàn)COUNT(字段名),對字段值為null的,不會(huì)計(jì)數(shù),因此上面3個(gè)SQL可以合并為:
SELECT COUNT(1) as 搜索次數(shù), COUNT(b.keyword) as 下載次數(shù)
? FROM search a LEFT JOIN down b ON a.keyword=b.keyword
?WHERE a.keyword='key' ;
這個(gè)SQL里的“搜索次數(shù) -下載次數(shù)=未下載次數(shù)”
其它補(bǔ)充:通常情況下,都是用下列sql統(tǒng)計(jì)記錄條數(shù):
SELECT COUNT(1)
SELECT COUNT(*)
SELECT COUNT(主鍵)
也有用 SELECT COUNT(0)
上 述4種COUNT方法完全一致,因?yàn)橹麈I不可能為null,另外以前的COUNT有差異的說法,在最新的數(shù)據(jù)庫,這些差異都沒有了,需要注意的就是少用 COUNT(字段名),因?yàn)樗鼤?huì)排除NULL值,導(dǎo)致計(jì)數(shù)跟結(jié)果不一致,推薦用COUNT(1),簡單明了,下面是測試結(jié)果示意:
首發(fā):http://beinet.cn
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
