Python使用MySQLdb调用MySQL数据库时报错
File "./daily-rep.py", line 96, in <module>
getdata()
File "./daily-rep.py", line 48, in getdata
cursor.execute(sql)
File "/usr/lib64/python2.7/site-packages/MySQLdb/cursors.py", line 205, in execute
self.errorhandler(self, exc, value)
File "/usr/lib64/python2.7/site-packages/MySQLdb/connections.py", line 36, in defaulterrorhandler
raise errorclass, errorvalue
_mysql_exceptions.OperationalError: (1055, "Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'zabbix.h.name' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by")
经查,是MySQL5.7的sql_mode问题,修改即可。
#查询当前sql_mode
mysql -uroot -p
mysql ->select @@sql_mode;
+-------------------------------------------------------------------------------------------------------------------------------------------+
| @@sql_mode |
+-------------------------------------------------------------------------------------------------------------------------------------------+
| ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION |
+-------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)
修改SQL mode
vim /etc/mysql/my.cnf
#在打开的my.cnf文件中添加
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
重启数据库。