Laravel模型使用groupby函数报错

环境

Laravel版本:7.0
MySQL版本:5.7.26
php 7.2

MySQL报错如下:

SQLSTATE[42000]: Syntax error or access violation: 1055 Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'tp_6.article.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 article group by user_id)
  • 产生原因:

    由于mysql默认开启严格模式,当select字段比group by使用到的字段多的时候,会报错。

  • 解决方案:

    在laravel的config/database.php中设置 strictfalse,关闭严格模式,如下图:

    Laravel模型使用groupby函数报错

ps : 关闭严格模式会有一些其他的影响,比如varchar字符长度超过了指定的长度,会截取到指定长度,而不会报错等

特别感谢

参考博客:Laravel的groupBy()报错问题处理

本作品采用《CC 协议》,转载必须注明作者和本文链接
EMin
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 0
(= ̄ω ̄=)··· 暂无内容!

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!