6

我写了这个带有分页的查询

$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 BY 子句,则混合没有 GROUP 列的 GROUP 列 (MIN(),MAX(),COUNT(),...) 是非法的

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

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

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

4

2 回答 2

23

当您使用聚合函数时,MIN(),MAX(),COUNT() AVG()您必须使用Group BY

但最近MYSQL你也必须使用 select 中的所有列作为一个 group By 。

在您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。

于 2018-04-16T07:06:38.867 回答
0

您可以在模式数组中评论 ONLY_FULL_GROUP_BY 行

于 2019-09-24T16:12:27.320 回答