解决laravel出现Syntax error or access violation: 1055 '***' isn't in GROUP BY报错问题

earnpls • 368 次浏览 • 0 个回复 • 2018年02月10日

laravel 5.3以后默认开启mysql严格模式(strict),在mysql在严格模式下, 并且开启了ONLY_FULL_GROUP_BY的情况下,我们SELECT的字段没有出现在group by语句中会报错;如何解决呢?只要关闭了严格模式就不会报错。

如下Demo

public static function orders($phase)
{
    return self::select(DB::raw("SUM(orders) as orders"),"type","users_id","name")
                ->groupBy("type","name")
                ->where("phase",$phase)
                ->get();
}

会出现如下错误,当然*号内的内容是不同的

Syntax error or access violation: 1055 '***' isn't in GROUP BY

解决办法

laravel出现上述错误是sql_mode设置导致的问题,修改config/database.php配置文件的strict => false即可关闭了严格模式:

'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,
],

原创文章,转载请注明 :解决laravel出现Syntax error or access violation: 1055 '***' isn't in GROUP BY报错问题 - Laravel学习网
原文出处: https://phpartisan.cn/news/77.html
问题交流群 :168117787
提交评论
要回复文章请先登录注册
用户评论
  • 没有评论
[ 配置教程 ] 在ubuntu16.04中部署LNMP环境(php7+maridb且开启maridb远程以及nginx多域名访问 )并配置laravel环境 [ laravel拓展 ] 使用laravel agent轻松识别客户端信息以及设备信息