php select limit倒序,Thinkphp5 海量数据查询分页(paginate)ORDER BY和LIMIT 造成查询很慢的临时解决办法...

一台数据监控后台,图省事就用Thinkphp5写了下,数据30万的时候分页就很卡了,基本上6秒才能查询执行完。

基本上是 ORDER BY 和 LIMIT 造成的查询很慢,详细的就不多说了,下面贴一下我自己的解决办法,没有深入去处理,只是个临时解决办法,仅供参考。

涉及文件:\thinkphp\library\think\db\Query.php

涉及函数:paginate

涉及代码:

//$results = $this->options($options)->bind($bind)->page($page, $listRows)->select();  这是原本的查询代码,注释掉

下面两行是新增的查询代码:

$sql="SELECT * FROM ".$options['table']." INNER JOIN (SELECT id FROM ".$options['table']." ORDER BY ".key($options['order'])." ".current($options['order'])." LIMIT ".(intval($page)-1)*intval($listRows).",".$listRows.") as a USING (id)";

$results = $this->query($sql);

运行测试SQL:

SELECT * FROM 表名 INNER JOIN (SELECT 主键 FROM 表名 ORDER BY 主键 desc LIMIT 0,20) as a USING (主键)

大致是这个情况,现在无论怎么访问都能控制在 0.几秒 查询完成。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当使用POST方式提交表单时,ThinkPHP默认使用 $_POST 变量来获取提交的数据,而 $_POST 是无法直接获取分页参数的,因此分页失效了。但是你可以使用 $_REQUEST 变量来获取提交的数据,它可以同时获取 GET 和 POST 的数据。具体的解决方法如下: 1. 修改控制器中的查询代码,使用 $_REQUEST 变量来获取提交的数据。 ```php public function index() { $pageSize = 10; $page = isset($_REQUEST['page']) ? intval($_REQUEST['page']) : 1; $where['name'] = isset($_REQUEST['name']) ? $_REQUEST['name'] : ''; $list = Db::name('user')->where($where)->paginate($pageSize, false, ['page' => $page]); $this->assign('list', $list); return $this->fetch(); } ``` 2. 修改模板中的分页代码,使用 $_REQUEST 变量来生成分页链接。 ```html <div class="page"> <ul> <?php if ($list->currentPage() > 1): ?> <li><a href="<?php echo url('/index', ['page' => $_REQUEST['page'] - 1]); ?>">上一页</a></li> <?php endif; ?> <?php for ($i = 1; $i <= $list->lastPage(); $i++): ?> <li <?php if ($list->currentPage() == $i): ?>class="active"<?php endif; ?>><a href="<?php echo url('/index', ['page' => $i]); ?>"><?php echo $i; ?></a></li> <?php endfor; ?> <?php if ($list->currentPage() < $list->lastPage()): ?> <li><a href="<?php echo url('/index', ['page' => $_REQUEST['page'] + 1]); ?>">下一页</a></li> <?php endif; ?> </ul> </div> ``` 通过这种方式,就可以在使用 POST 方式提交表单时,正确地生成分页链接,实现分页功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值