视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
关于Mysql的数据列表的分页显示_MySQL
2020-11-09 18:10:52 责编:小采
文档


bitsCN.com

网站 刚发布时没有几篇文章,首页基本上是列出全部内容,最近文章多起来了,需要弄个分页显示。

网站用的是MySQL数据库,获取某一页的文章的代码基本如下:

int start = countPerPage*(page-1);

执行select * from .... limit start, countPerPage

于分页时需要列出一些页码,这就需要获得文章总数,一般用select count(*) .......就能获取数据。这里的问题在于为了实现分页,需要对数据库进行两次查询,效率不高,所以想是不是可以用一次查询解决这个问题,上网搜了一下,果然找到答案:

mysql> SELECT SQL_CALC_FOUND_ROWS * FROM ... WHERE ... LIMIT 10;

mysql> SELECT FOUND_ROWS();

参数SQL_CALC_FOUND_ROWS表示查询时记录查询结果数

函数FOUNT_ROWS返回上次查询(SQL_CALC_FOUND_ROWS)的结果数

虽然也需要select两次,不过第2次select不需要查询记录,直接返回结果,效率可以提高一倍

bitsCN.com

下载本文
显示全文
专题