程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> 關於MYSQL數據庫 >> MYSQL中統計查詢結果總行數的便捷方法省去count(*)

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

編輯:關於MYSQL數據庫
    查看手冊後發現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;
    }

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved