搜索
系统检测到您的用户名不符合规范:

tp5修复group by后分页异常

浏览:4088 发布日期:2017年01月19日 分类:ThinkPHP5专区 关键字: tp5修复group by后分页异常
框架:tp5.0.0

发现类似$model->group('area_id')->paginate(2)的分页不对,修改\thinkphp\library\think\Query的count方法(494行)如下:public function count($field = '*')
{
$options = $this->getOptions();

/*
* 修复group情况下count不正确
* @author 王荣 老倪
* @version 2017年1月19日
*/
if($options['group']){
$bind = $this->bind;

//构建lists sql
$lists = $this->options($options)->field('count(*)')->bind($bind)->fetchSql(true)->select();

//构建子查询统计sql
$sql = "select count(*) as tp_count from ($lists) a";

$resultSet = $this->query($sql, $bind);

return $resultSet[0]['tp_count'];
}

return $this->value('COUNT(' . $field . ') AS tp_count', 0);

}
https://www.olcms.com/2036
最佳答案
评论() 相关
后面还有条评论,
评论支持使用[code][/code]标签添加代码
您需要登录后才可以评论 登录 | 立即注册
收藏
彼时、年少2o13
积分:1261 等级:LV3
热点推荐
(追記) (追記ここまで)
最新更新

我们

合作

网站

信息

ThinkPHP 是一个免费开源的,快速、简单的面向对象的 轻量级PHP开发框架 ,创立于2006年初,遵循Apache2开源协议发布,是为了敏捷WEB应用开发和简化企业应用开发而诞生的。ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,也注重易用性。并且拥有众多的原创功能和特性,在社区团队的积极参与下,在易用性、扩展性和性能方面不断优化和改进,已经成长为国内最领先和最具影响力的WEB应用开发框架,众多的典型案例确保可以稳定用于商业以及门户级的开发。

AltStyle によって変換されたページ (->オリジナル) /