mysql的SQL_CALC_FOUND_ROWS 使用

在很多分页的程序中都这样写:

SELECT COUNT(*) from `table` WHERE ……;   查出符合条件的记录总数
SELECT * FROM `table` WHERE …… limit M,N; 查询当页要显示的数据
这样的语句可以改成:
SELECT SQL_CALC_FOUND_ROWS * FROM `table` WHERE ……   limit M, N;
SELECT FOUND_ROWS();
这样只要执行一次较耗时的复杂查询可以同时得到与不带limit同样的记录条数
第二个 SELECT返回一个数字,指示了在没有LIMIT子句的情况下,第一个SELECT返回了多少行 (若上述的 SELECT语句不包括 SQL_CALC_FOUND_ROWS 选项,则使用LIMIT 和不使用时,FOUND_ROWS() 可能会返回不同的结果)。
eg:
$sql = “SELECT SQL_CALC_FOUND_ROWS  t.tid,t.fid,f.name,t.subject,t.dateline FROM {$tablepre}threads AS t JOIN  {$tablepre}forums AS f ON t.fid=f.fid “;
$sql .= ” WHERE t.tid=’$tid'”;
$query = $db->query($sql);

$total = $db->fetch_row($db->query(“SELECT FOUND_ROWS()”));
$highlight[‘total’] = $total[0];

while($result=$db->fetch_row($query)){
list($tmp[‘tid’],$tmp[‘fid’],$tmp[‘forumName’],$tmp[‘threadName’],$tmp[‘dateline’]) = $result;
$tmp[‘dateline’] = date(‘H:i’,$tmp[‘dateline’]);
$highlight[‘result’][] = $tmp;
unset($tmp);
}
return json_encode($highlight);

相关文章

发表评论

返回顶部