統(tǒng)計(jì)所有記錄的數(shù)量:
成都創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括嘉定網(wǎng)站建設(shè)、嘉定網(wǎng)站制作、嘉定網(wǎng)頁(yè)制作以及嘉定網(wǎng)絡(luò)營(yíng)銷策劃等。多年來(lái),我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,嘉定網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到嘉定省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
SELECT COUNT(*) FROM table_name
統(tǒng)計(jì)某列的數(shù)量:
SELECT COUNT(column_name) FROM table_name
where 條件
2020-03-01
對(duì)于count的函數(shù)的使用,我們常見的一個(gè)錯(cuò)誤是在括號(hào)內(nèi)隨意指定一個(gè)列去統(tǒng)計(jì)結(jié)果集的行數(shù)。但只有指定的行確實(shí)都是有值的時(shí)候,統(tǒng)計(jì)的才是實(shí)際的行數(shù),否則可能統(tǒng)計(jì)的結(jié)果并不是實(shí)際的行數(shù)。而對(duì)于MyISAM存儲(chǔ)引擎,如果某一列的值確實(shí)不可能為null時(shí),MySQL內(nèi)部就會(huì)將count()函數(shù)優(yōu)化成count(*),若沒(méi)有帶where條件,此時(shí)計(jì)算速度是非??斓?,因?yàn)榇藭r(shí)沒(méi)有實(shí)際的去計(jì)算表的行數(shù)。
總結(jié): 對(duì)于MyISAM存儲(chǔ)引擎,不帶where條件的count(*)是非??斓?。
技巧:
利用上述MyISAM的count(* )特性,加速一些特定查詢條件的count()查詢。
如:
對(duì)于select count(* ) from tablename where id 10; 可以做如下的反轉(zhuǎn)查詢:
select (select count(* ) from tablename) - count(* ) from tablename where id 10;
因?yàn)檫@樣在查詢階段MySQL將子查詢當(dāng)做一個(gè)常數(shù)來(lái)處理,大大減少了掃描的行數(shù)。
可以用count()方法,例如,select count(*) from a, 可以查詢出表a的所有行數(shù),也就是總數(shù)
做一些數(shù)據(jù)庫(kù)查詢,不僅希望得到要查詢的結(jié)果,還希望方便地計(jì)算一下查詢結(jié)果中有多少條記錄。我通常的做法是:
$q = "select * from $fromTable where $where limit $start,$pageSize";
$r = mysql_query($q);
$q = "select count(*) from $fromTable where $where";
$cnt = mysql_query($q);
當(dāng) 然可以用mysql_num_rows()或者mysql_affected_rows()來(lái)在第一次查詢后得到記錄數(shù)目,但是這兩個(gè)函數(shù)返回的都是查詢 后得到的結(jié)果的數(shù)目,是受limit語(yǔ)句的影響的。很多情況下,需要知道這條查詢語(yǔ)句在沒(méi)有l(wèi)imit的情況下結(jié)果總數(shù),比如分頁(yè)查詢。
mysql 中本身支持一種更好的方法來(lái)達(dá)到上面的效果,那就是使用SQL_CALC_FOUND_ROWS和FOUND_ROWS()函數(shù)。