1

我创建了一个数据库视图,当我对这个视图使用 laravel 分页时,它会抛出:

SQLSTATE[42000]: Syntax error or access violation: 1140 Mixing of GROUP columns (MIN(),MAX(),COUNT(),...) with no GROUP columns is illegal if there is no GROUP BY clause (SQL: select count(*) as aggregate from `parameter_log_site_detail` where `site_id` = EPE)

但是此错误仅在实时服务器中弹出。分页在本地服务器上工作正常。

数据库视图: (parameter_log_site_detail)

select `t`.`site_id` AS `site_id`,cast(`t`.`logged_at` as date) AS `logged_on`,`t`.`daily_generation` AS `daily_generation`,`t`.`reading` AS `tot_reading` from `parameter_log_tab` `t` order by cast(`t`.`logged_at` as date) desc

模型:

public function scopeSiteDailyReadings($query)
{
    return $query->from('parameter_log_site_detail');
}

控制器:

$generations = EnergyGeneration::siteDailyReadings()->where('site_id', $site_id)->orderBy('logged_on', 'desc')->paginate(15);

实时服务器信息

MySQL Server version: 5.6.37 - MySQL Community Server (GPL)
PHP version: 5.6.30
Laravel version: 5.4

本地服务器信息(正常运行的地方)

MySQL Server version: 5.7.19 - MySQL Community Server (GPL)
PHP version: 7.1.7
Laravel version: 5.4

有人可以解释这可能是什么原因吗?我读到了 ONLY_FULL_GROUP_BY。但无法弄清楚这是因为服务器版本是5.6.*的原因。

4

1 回答 1

2

可以在 MySQL 5.6 中设置 SQL 模式 ONLY_FULL_GROUP_BY,但默认情况下未设置(请参阅https://dev.mysql.com/doc/refman/5.6/en/sql-mode.html)。

啊哈,我看到您的评论出现在上面,您已确认在本地服务器(MySQL 5.7)上设置了 ONLY_FULL_GROUP_BY。

我认为您在问题描述中误报了某些内容。如果本地有 ONLY_FULL_GROUP_BY 而 live 没有,您应该在本地服务器上得到错误,但不会在实时服务器上得到错误。

我建议你确保在开发中使用与生产中使用的版本相同的版本,并匹配相同的 SQL 模式。这将防止开发过程中的混乱。

我对 PHP 的版本提出了同样的建议。如果您在开发中使用一些新的 PHP 7 功能,然后部署到您的 PHP 5.6 实时服务器,它们将无法工作。

你描述的SQL应该没问题:

select count(*) as aggregate from `parameter_log_site_detail` where `site_id` = EPE

这实际上没问题,即使您有 ONLY_FULL_GROUP_BY。select count(*)对表中的所有匹配行进行 a 肯定是合法的。此查询不需要 GROUP BY 子句。

但是,如果将聚合列与非聚合列混合使用,则会违反 ONLY_FULL_GROUP_BY 要求,因为非聚合列会不明确。

select id, count(*) as aggregate from ...

我想知道 Laravel 是否在准备查询之前将额外的列插入到您的选择列表中。您必须启用 MySQL 查询日志才能确定。

我注意到在 Laravel 问题上有一些关于这个错误的讨论:https ://github.com/laravel/framework/issues/15232

该线程中的几个用户表示解决问题的解决方案是'strict'=>false在您的 Laravel config/database.php 中设置。

但我敢打赌,根本原因是 Laravel 正在修改您的 SQL 查询。

于 2017-08-26T18:37:29.687 回答