mysql统计关键词个数_MYSQL中统计查询结果总行数的便捷方法省去count(*)

本文介绍了MySQL中SQL_CALC_FOUND_ROWS关键词的用途,它用于在查询时统计满足条件的结果总数,不受LIMIT影响。通过结合found_rows()函数,可以避免重复的COUNT(*)查询,提高性能。示例代码展示了如何在实际应用中使用这一技巧。
摘要由CSDN通过智能技术生成

查看手册后发现SQL_CALC_FOUND_ROWS关键词的作用是在查询时统计满足过滤条件后的结果的总数(不受 Limit 的限制)具体使用如下,感兴趣的朋友可以学习下 MYSQL的关键词 : SQL_CALC_FOUND_ROWS 查看手册后发现此关键词的作用是在查询时统计满足过滤条件后的结

查看手册后发现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;

}

f68f2add0b68e4f9810432fce46917b7.png

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值