php – 升级到laravel 5.3之后不工作的组

前端之家收集整理的这篇文章主要介绍了php – 升级到laravel 5.3之后不工作的组前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
这是在laravel 5.2上运行的代码

$menus = CmsMenuItem::groupBy('menu_id')->get();

但现在它抛出了错误

sqlSTATE[42000]: Syntax error or access violation: 1055 Expression #1
of SELECT list is not in GROUP BY clause and contains nonaggregated
column ‘convertifier_cms.cms_menu_items.id’ which is not functionally
dependent on columns in GROUP BY clause; this is incompatible with
sql_mode=only_full_group_by (sql: select * from ‘cms_menu_items’ group
by ‘menu_id’)

我也试过了

`strict => false`

在database.PHP但没有效果

解决方法

试试这个数据库配置.

'MysqL' => [
            'driver' => 'MysqL','host' => env('DB_HOST','localhost'),'port' => env('DB_PORT','3306'),'database' => env('DB_DATABASE','forge'),'username' => env('DB_USERNAME','password' => env('DB_PASSWORD',''),'charset' => 'utf8','collation' => 'utf8_unicode_ci','prefix' => '','strict' => false,'engine' => null,],

并以这种方式使用查询

$menus =DB::table('cms_menu_item')
    ->select('*')
    ->groupBy('menu_id')
    ->get();

猜你在找的Laravel相关文章