做一些數(shù)據(jù)庫查詢,不僅希望得到要查詢的結(jié)果,還希望方便地計(jì)算一下查詢結(jié)果中有多少條記錄。我通常的做法是:
為企業(yè)提供成都網(wǎng)站制作、網(wǎng)站建設(shè)、網(wǎng)站優(yōu)化、成都全網(wǎng)營銷推廣、競(jìng)價(jià)托管、品牌運(yùn)營等營銷獲客服務(wù)。創(chuàng)新互聯(lián)公司擁有網(wǎng)絡(luò)營銷運(yùn)營團(tuán)隊(duì),以豐富的互聯(lián)網(wǎng)營銷經(jīng)驗(yàn)助力企業(yè)精準(zhǔn)獲客,真正落地解決中小企業(yè)營銷獲客難題,做到“讓獲客更簡(jiǎn)單”。自創(chuàng)立至今,成功用技術(shù)實(shí)力解決了企業(yè)“網(wǎng)站建設(shè)、網(wǎng)絡(luò)品牌塑造、網(wǎng)絡(luò)營銷”三大難題,同時(shí)降低了營銷成本,提高了有效客戶轉(zhuǎn)化率,獲得了眾多企業(yè)客戶的高度認(rèn)可!
$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()來在第一次查詢后得到記錄數(shù)目,但是這兩個(gè)函數(shù)返回的都是查詢 后得到的結(jié)果的數(shù)目,是受limit語句的影響的。很多情況下,需要知道這條查詢語句在沒有l(wèi)imit的情況下結(jié)果總數(shù),比如分頁查詢。
mysql 中本身支持一種更好的方法來達(dá)到上面的效果,那就是使用SQL_CALC_FOUND_ROWS和FOUND_ROWS()函數(shù)。
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(*),若沒有帶where條件,此時(shí)計(jì)算速度是非??斓?,因?yàn)榇藭r(shí)沒有實(shí)際的去計(jì)算表的行數(shù)。
總結(jié): 對(duì)于MyISAM存儲(chǔ)引擎,不帶where條件的count(*)是非??斓摹?/p>
技巧:
利用上述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ù)來處理,大大減少了掃描的行數(shù)。
用mysql語句顯示圖書總數(shù)數(shù)量
在mysql中,可以使用SELECT語句查詢數(shù)據(jù),并利用COUNT()函數(shù)統(tǒng)計(jì)查詢結(jié)果的數(shù)量,語法“SELECT COUNT(*) FROM 表名 [...];”或“SELECT COUNT(字段名) FROM 表名 [...];”。
統(tǒng)計(jì)所有記錄的數(shù)量:
SELECT COUNT(*) FROM table_name
統(tǒng)計(jì)某列的數(shù)量:
SELECT COUNT(column_name) FROM table_name
where 條件