MYSQL中統計查詢結果總行數的便捷方法省去count(*)

來源:互聯網
上載者:User
查看手冊後發現SQL_CALC_FOUND_ROWS關鍵詞的作用是在查詢時統計滿足過濾條件後的結果的總數(不受 Limit 的限制)具體使用如下,感興趣的朋友可以學習下 

MYSQL的關鍵詞 :
SQL_CALC_FOUND_ROWS
查看手冊後發現此關鍵詞的作用是在查詢時統計滿足過濾條件後的結果的總數(不受 Limit 的限制)

例如:

複製代碼 代碼如下:
SELECT SQL_CALC_FOUND_ROWS tid FROM cdb_threads WHERE fid=14 LIMIT 1,10;


假設滿足條件的有1000條,這裡返回10條。
立即使用

複製代碼 代碼如下:
SELECT found_rows() AS rowcount;


則返回的 rowcount 為1000;
這樣節省了SELECT count(*) AS rowcount的重複查詢,可以節省比較可觀的時間。

以下是該放在在遊味中的應用:

複製代碼 代碼如下:


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中滿足條件的行數,與LIMIT子句無關
$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;
}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.