MySQL 常见问题

list is not in GROUP BY clause and contains nonaggre的问题

问题出现的原因:

MySQL 5.7.5及以上功能依赖检测功能。如果启用了ONLY_FULL_GROUP_BY SQL模式(默认情况下),MySQL将拒绝选择列表,HAVING条件或ORDER BY列表的查询引用在GROUP BY子句中既未命名的非集合列,也不在功能上依赖于它们。(5.7.5之前,MySQL没有检测到功能依赖关系,默认情况下不启用ONLY_FULL_GROUP_BY。)

解决方法一

用sql查询:

select @@global.sql_mode
ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION

去掉ONLY_FULL_GROUP_BY,重新设置值。

set @@global.sql_mode
='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';

解决方法二:

$ sudo vim /etc/mysql/conf.d/mysql.cnf
$ sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf

$ sudo vim /etc/mysql/my.cnf

滚动到文件底部复制并粘贴

[mysqld]
max_connections = 1024
max_allowed_packet = 1024M
sql_mode = STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTIO

保存并退出输入模式

$ sudo service mysql restart

Can not connect to MySQL server. Too many connections

方式一,通过命令修改

很显然这是数据库连接数量过多问题,修改最大连接数即可
查看最大连接数
show variables like "max_connections";
修改最大连接数
set GLOBAL max_connections=xxx
此方法是即时生效的,不需要重启mysql服务

方式二、修改my.cnf

打开mysql的配置文件vim /etc/my.cnf,加入max_connections=xxx 一行(如果有,直接修改值即可),然后重启服务:/etc/init.d/mysqld restart,此时生效。

未完待续。。。

本作品采用《CC 协议》,转载必须注明作者和本文链接
讨论数量: 0
(= ̄ω ̄=)··· 暂无内容!

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!
未填写
文章
247
粉丝
17
喜欢
213
收藏
58
排名:732
访问:9674
私信
所有博文
社区赞助商