Skip to content

数据库模式修改 sql-mode

很多小伙伴在本地部署后访问站点会报下图这种错误

> 数据获取失败:SQLSTATE[42000]: Syntax error or access violation: 1055 Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column nc _saas.SysUserRole.id' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

这是因为在MySQL 5.7后,MySQL默认开启了SQL_MODE严格模式,对数据进行严格校验。我们需要修改数据库配置

一、本地部署数据库修改

1.打开本地部署软件phpstudy,侧边栏选择设置,点击文件位置,选择MySQL

2.弹出的文件夹中双击打开my.ini文件

3.找到sql_mode(注意:有点显示的是sql_mode,有点显示的是sql-mode两者都可以),将sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES改为

sql_mode=' '

4.修改完成后,重启mysql

二、宝塔部署数据库修改

1.在宝塔侧边栏选择软件商店,搜索mysql,选中相应的数据库,点击设置

> 注意:要修改哪个站点的数据库,就选择该站点的数据库版本号

2.点击配置修改,按住Ctrl+F键搜索sql-mode(注意:有点显示的是sql_mode,有点显示的是sql-mode两者都可以)

3.将sql-mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_VALUE_ON_ZERO改为

sql-mode=' '

4.修改后点击保存

5.重启mysql

基于 MIT 协议发布