《Mysql必讀MYSQL中統(tǒng)計(jì)查詢結(jié)果總行數(shù)的便捷方法省去count(*)》要點(diǎn):
本文介紹了Mysql必讀MYSQL中統(tǒng)計(jì)查詢結(jié)果總行數(shù)的便捷方法省去count(*),希望對您有用。如果有疑問,可以聯(lián)系我們。
MYSQL的關(guān)鍵詞 :
SQL_CALC_FOUND_ROWS
查看手冊后發(fā)現(xiàn)此關(guān)鍵詞的作用是在查詢時(shí)統(tǒng)計(jì)滿足過濾條件后的成果的總數(shù)(不受 Limit 的限制)
例如:
代碼如下:
SELECT SQL_CALC_FOUND_ROWS tid FROM cdb_threads WHERE fid=14 LIMIT 1,10;
假設(shè)滿足條件的有1000條,這里返回10條.
立刻使用
代碼如下:
SELECT found_rows() AS rowcount;
則返回的 rowcount 為1000;
這樣節(jié)省了SELECT count(*) AS rowcount的重復(fù)查詢,可以節(jié)省比擬可觀的時(shí)間.
以下是該放在在游味中的應(yīng)用:
代碼如下:
function mail_list_sent( $uid, $start ) {
// 注意SQL_CALC_FOUND_ROWS uid之間沒有逗號
$query = "SELECT SQL_CALC_FOUND_ROWS uid, real_name, current_city, msg_uid, sender_flag, ".
"msg_title, msg_content FROM " . TT_DBTABLEPRE . "mailbox as mb1, " . TT_DBTABLEPRE .
"user as usr1 WHERE mb1.sender_id=usr1.uid AND mb1.sender_id=$uid AND sender_flag > 0 LIMIT $start, " . TT_PAGESIZE;
$mails = $this->db->fetch_all( $query );
//查詢SELECT中滿意條件的行數(shù),與LIMIT子句無關(guān)
$max_count = $this->db->fetch_first( "SELECT found_rows() AS rowcount" );
$tmp['state_code'] = 200;
$tmp['info'] = "OK";
$tmp['list'] = $mails;
$data = json_encode( $tmp );
return $data;
}
維易PHP培訓(xùn)學(xué)院每天發(fā)布《Mysql必讀MYSQL中統(tǒng)計(jì)查詢結(jié)果總行數(shù)的便捷方法省去count(*)》等實(shí)戰(zhàn)技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培養(yǎng)人才。
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.fzlkiss.com/jiaocheng/9826.html