其实我也不知道标题是不是应该这样写,因为想不到更好的标题了。 问题的来源是:
比如页面上有一个列表项是来自数据库。列表页上每页列出十项数据,有分页,还有“总共xx条”的显示项。 现在有两种数据查询方式: 一种是,select * from table;将所有的数据都查询出来,统计返回多少行的数据,将这个数据显示在“总共xx条”这里,然后再从得到的数据里面截取用户要求的第n页数据。
我看到有几个软件是这么写的。(php的),我觉得这样是少了查询次数,但是查询速度会不好吧,犹其是数据量很大的时候,要是数据库在远程就更死翘翘了。 另一种是用两个语句,先用select count('id') from table 得到总共的数据条数,显示在“总共xx条”,然后用select * from table where page = n;查询出用户要求显示的第n页数据。
我觉得这个方法会好点,查询会快点。但是问题是,如果页面上有很多查询项,比如dz的帖子列表项,有那么多用户,每个用户的用户信息,每个用户的权限,每个用户发的帖子,等等,这些都不在同一个表里,难道都是分多次分别查询的吗?求解答,平时要不要尽量查询少点信息,但是可以多查几次,这样好不好。
比如页面上有一个列表项是来自数据库。列表页上每页列出十项数据,有分页,还有“总共xx条”的显示项。 现在有两种数据查询方式: 一种是,select * from table;将所有的数据都查询出来,统计返回多少行的数据,将这个数据显示在“总共xx条”这里,然后再从得到的数据里面截取用户要求的第n页数据。
我看到有几个软件是这么写的。(php的),我觉得这样是少了查询次数,但是查询速度会不好吧,犹其是数据量很大的时候,要是数据库在远程就更死翘翘了。 另一种是用两个语句,先用select count('id') from table 得到总共的数据条数,显示在“总共xx条”,然后用select * from table where page = n;查询出用户要求显示的第n页数据。
我觉得这个方法会好点,查询会快点。但是问题是,如果页面上有很多查询项,比如dz的帖子列表项,有那么多用户,每个用户的用户信息,每个用户的权限,每个用户发的帖子,等等,这些都不在同一个表里,难道都是分多次分别查询的吗?求解答,平时要不要尽量查询少点信息,但是可以多查几次,这样好不好。
解决方案 »
- MySQL中怎么让一个列的默认值等于另一个列的值
- mysql,30G二进制文件的数据恢复,真心求教
- postgres存储过程问题,谢啦...
- 这怎的统计SQL怎么写
- 用mysql写应该如何写分层查询?谢谢!
- MYSQL查询语句中的 in 是否仅针对 数字字段有效
- 请问一个关于多次left join 同一个表的问题
- MySql是不是不支持中文?
- 请大家访问我的个人站点--Delphi桃花岛,绝对值得去一趟,有数据库辅助设计Case工具(支持MySQL),设计MySQL再不用输入太多代码了
- vs2010与mysql数据库如何建立连接 进行数据交互
- 一条“稍”复杂的sql 求改编一下 现在有点慢。。。。
- 支持mysql分区表的版本有哪些
select * from table where page = n;
更正为
select * from table limit n,10;
写成页面url了。不好意思。
这么说,总数还是要单独用count单独查下喽。
1. 别用 select * ,换成你需要的字段
2. count(*),或者 count(1) ,别用具体的字段。
3. 你不就是一个分页嘛纠结那么多干嘛。
第二个显示总共多少条记录 select count(*) from tb;
查出所有数据来数总条数是相当耗资源的。
不能为了显示一页的数据把所有明细都查出来。