【问题标题】:phalcon querybuilder total_items always returns 1phalcon querybuilder total_items 总是返回 1
【发布时间】:2014-10-19 13:39:04
【问题描述】:

我通过createBuilder() 进行查询,并在执行时 (getQuery()->execute()->toArray()) 我得到了 10946 个元素。我想给它分页,所以我把它传递给:

$paginator = new \Phalcon\Paginator\Adapter\QueryBuilder(array(
    "builder" => $builder,
    "limit" => $limit,
    "page" => $current_page
));

$limit25$current_page1,但是当这样做时:

$paginator->getPaginate();

$page->total_items;

返回 1

这是一个错误还是我错过了什么?

UPD:似乎在计算项目时它使用了带限制的创建 sql。限制是什么没有区别,限制除以每页的项目总是等于1。我可能弄错了。

UPD2:同事帮我解决了这个问题,错误出现在 phalcon 产生的查询中:count() of the group by counts grouped elements。所以解决方法如下:

$dataCount = $builder->getQuery()->execute()->count();
$page->next = $page->current + 1;
$page->before = $page->current - 1 > 0 ? $page->current - 1 : 1;
$page->total_items = $dataCount;
$page->total_pages = ceil($dataCount / 100);
$page->last = $page->total_pages;

【问题讨论】:

  • 有机会分享其余代码吗?由此很难猜测。也许展示你如何构建查询?正在加入/分组吗?
  • $page->items 呢?它只有一项吗?
  • 它有25,根据限制是正确的。

标签: phalcon query-builder paginator


【解决方案1】:

我知道这不是一个很好的答案,但这很可能是一个错误。 Phalcon 的好人承担了一项庞大的工作,在他们的空闲时间里无法正常完成,而 PHQL、Volt 和其他大型但非核心组件之类的东西并没有像我们希望的那样受到关注。此外,鉴于过去 6 个月的大部分时间都花在了 v2 上,因此有近 500 个关于此类内容的错误,而且还在不断增加。我在 ORM、Volt、Validation 和 Session 中遇到了相当多的问题,这最终让我坚持使用其他不那么酷但更成熟的解决方案。当 v2 发布时,我相信所有的注意力都会集中在 bug 列表和测试上,在此之前我们主要靠自己。鉴于现在全是 C,只有少数发烧友参与其中,而 v2 也将改变。

如果这是您遇到的唯一问题,最好的方法是更新您的查询以获取您自己需要的信息,而无需 getPaginate()

【讨论】:

  • 我知道有很多错误。但是forum.phalconphp.com/discussion/3251/… 是一周前的帖子,没有明显的回应。我希望至少得到一个像“这是一个错误,我们当时不会修复它,做一个解决方法”这样的答案,然后我会在一周前立即解决我的问题,但我不是在不确定中等待。
  • :) 记住,没有人欠你任何东西,但我能感受到男人的痛苦。我在想有人会在这里说些什么,因为有几个人知道他们在 ORM 周围的方式。下一次假设有一个错误,如果你检查了五次并且它不起作用——它很有可能是。现在大部分努力都在 v2 上,如果它们开始传播,它不太可能很快出现。应该保持这样的事情,但我们拥有我们所拥有的。核心相当稳定,经过一年多的使用,没有什么是无法解决的,至少我就是这样。
猜你喜欢
  • 1970-01-01
  • 2016-11-21
  • 2019-10-10
  • 2014-04-13
  • 2017-03-20
  • 2013-11-04
  • 2011-12-09
  • 2012-07-08
  • 1970-01-01
相关资源
最近更新 更多