亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Sql Server中COUNT(字段名)跟COUNT(*)的特殊不

系統 3185 0

今天有個需求,有2張表:
1、一個“搜索記錄”表search,一個“搜索后下載記錄”表down
2、映射關系:每一個下載記錄對應一條搜索記錄,
????????????????????????? 第個搜索記錄對應一條下載記錄,也可能沒有下載記錄

現在需要統計某個搜索詞的搜索次數、下載次數 和 未下載次數
正常情況下需要統計3次:
SELECT COUNT(*) as 搜索次數 FROM search WHERE keyword='key';
SELECT COUNT(*) as 下載次數 FROM down WHERE keyword='key';
SELECT COUNT(*) as 未下載次數
? FROM search a LEFT JOIN down b ON a.keyword=b.keyword
?WHERE a.keyword='key' AND?b.keyword IS NULL;

通過查詢MSDN和相關試驗后,發現COUNT(字段名),對字段值為null的,不會計數,因此上面3個SQL可以合并為:
SELECT COUNT(1) as 搜索次數, COUNT(b.keyword) as 下載次數
? FROM search a LEFT JOIN down b ON a.keyword=b.keyword
?WHERE a.keyword='key' ;

這個SQL里的“搜索次數 -下載次數=未下載次數”

其它補充:通常情況下,都是用下列sql統計記錄條數:
SELECT COUNT(1)
SELECT COUNT(*)
SELECT COUNT(主鍵)
也有用 SELECT COUNT(0)
上 述4種COUNT方法完全一致,因為主鍵不可能為null,另外以前的COUNT有差異的說法,在最新的數據庫,這些差異都沒有了,需要注意的就是少用 COUNT(字段名),因為它會排除NULL值,導致計數跟結果不一致,推薦用COUNT(1),簡單明了,下面是測試結果示意:
Sql Server中COUNT(字段名)跟COUNT(*)的特殊不同點


首發:http://beinet.cn

Sql Server中COUNT(字段名)跟COUNT(*)的特殊不同點


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦?。?!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 欧美性狂猛bbbbbbxxxx | 国产精品香蕉在线一区 | 精品久久在线 | 啪啪网站免费 | 欧美专区在线 | 日本国产一区二区三区 | 亚洲a成人 | 精品免费在线视频 | 欧美日韩91 | 久久中文字幕视频 | 毛片在线高清免费观看 | 中文字幕一级毛片视频 | 国产深夜福利 | 久久久久久a亚洲欧洲aⅴ | 香蕉尹人综合精品 | 日韩黄色网页 | 日韩狠狠操 | 湿湿影院在线观看 | 精品国产免费一区二区三区五区 | 奇米影视大全 | 亚洲你xx我xx网站 | 久久免费视频1 | 久久久麻豆 | 日日夜夜精品免费视频 | 狠狠的干狠狠的操 | 亚洲一区精品中文字幕 | 国产综合色在线视频区色吧图片 | 国产国拍亚洲精品福利 | 91专区在线观看 | 亚洲欧美高清视频 | 国产午夜不卡在线观看视频666 | 最新地址四虎www4hutv | 中文字幕在线不卡精品视频99 | 日韩精品一区二区三区中文字幕 | 日韩欧美毛片免费观看视频 | www神马我不卡影院免费观看 | 国产成人久久精品二区三区 | 国产精品亚洲综合 | 久久综合九色综合狠狠97 | 国产精选一区二区 | 亚洲最色 |