加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

Mysql必读MYSQL中统计查询结果总行数的便捷方法省去count(*)

发布时间:2020-12-12 02:56:38 所属栏目:MySql教程 来源:网络整理
导读:《Mysql必读MYSQL中统计查询结果总行数的便捷方法省去count(*)》要点: 本文介绍了Mysql必读MYSQL中统计查询结果总行数的便捷方法省去count(*),希望对您有用。如果有疑问,可以联系我们。 MYSQL的关键词 : SQL_CALC_FOUND_ROWS 查看手册后发现此关键词的作

《Mysql必读MYSQL中统计查询结果总行数的便捷方法省去count(*)》要点:
本文介绍了Mysql必读MYSQL中统计查询结果总行数的便捷方法省去count(*),希望对您有用。如果有疑问,可以联系我们。

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;
}

编程之家PHP培训学院每天发布《Mysql必读MYSQL中统计查询结果总行数的便捷方法省去count(*)》等实战技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培养人才。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读