php - 语法错误或访问冲突 : 1140 Mixing of GROUP columns laravel

标签 php laravel laravel-5 laravel-paginate

我已经用分页写了这个查询

$items = Item::select('items.*', 'sub_category_name', 'category_name', 'sub_category_slug', 'category_slug')
        ->join('sub_categories AS sc', 'sc.sc_id', 'items.sub_category_id')
        ->join('categories AS c', 'c.category_id', 'sc.category_id')
        ->where('items.is_active', '=', 1)
        ->where('sc.is_active', '=', 1)
        ->where('c.is_active', '=', 1)
        ->where('sc.sc_id', '=', $sub_category_id)
        ->paginate(1);

但它说

语法错误或访问冲突:1140 混合 GROUP 列 (MIN(),MAX(),COUNT(),...) 如果没有 GROUP BY 子句,则没有 GROUP 列是非法的

但是当我添加 ->groupBy('item_id');它说

语法错误或访问冲突:1055 'books.items.item_name' 不在 GROUP BY 中

但是当我在 groupBy 子句中执行 item_name 时,它​​会说到下一列的 groupBy。为什么?

最佳答案

当您使用像 MIN(),MAX(),COUNT() AVG() 这样的聚合函数时您必须使用 Group BY
但在最新 MYSQL你也必须使用 select 中的所有列作为一个组。

在您的 config/database.php关闭严格模式。

'mysql' => [
        'driver' => 'mysql',
        'host' => env('DB_HOST', 'localhost'),
        'port' => env('DB_PORT', '3306'),
        'database' => env('DB_DATABASE', 'forge'),
        'username' => env('DB_USERNAME', 'forge'),
        'password' => env('DB_PASSWORD', ''),
        'charset' => 'utf8',
        'collation' => 'utf8_unicode_ci',
        'prefix' => '',
        'strict' => false,
        'engine' => null,
    ],
'strict' => false之后,您也可以在单个列上使用 group by。

关于php - 语法错误或访问冲突 : 1140 Mixing of GROUP columns laravel,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49846961/

相关文章:

php - 使用 Laravel 5.3 的超薄图像裁剪器

laravel - Laravel 5 中两个字段组合的验证

php - AWS 上的 Laravel 应用程序。 503错误

php - map 上的最新 Foursquare 签到

php - 如何使用 Codeigniter 集成 Twig 模板?

mysql - 从 MySQL 的列中查找数组中的元素

php - 隐私设置的数据库模式设计

php - str_replace 不会替换阿拉伯字符

php - 如何使用字段获取 Zend 模型

laravel - 如何在 Laravel 中使用 str_replace