我一直在切换到拉曼SQL棒球数据库的脱机版本时遇到问题。我正在使用嵌入到EDX课程中的终端。此命令在Web终端上运行良好:
SELECT concat(m.nameFirst,concat(" ",m.nameLast)) as Player, p.IPOuts/3 as IP, p.W,p.L,p.H,p.BB,p.ER,p.SV,p.SO as K, p.IPOuts+p.W*5+p.SV+p.SO-p.BB-p.L-p.H as PTS, p.yearID as Year FROM Pitching p Inner Join Master m ON p.playerID=m.playerID WHERE p.yearID=2014 AND p.IPOuts>=50 GROUP BY m.playerID ORDER BY PTS DESC;
它正在运行SQL 5.5.46,但是当我使用运行5.7.10的脱机版本时,出现以下错误代码:
错误代码:1055。SELECT列表的表达式#1不在GROUP BY子句中,并且包含未聚合的列’stats.m.nameFirst’,该列在功能上不依赖于GROUP BY子句中的列。这与sql_mode = only_full_group_by不兼容
我一直在阅读许多解决人们问题的解决方案,但在这种情况下它们没有帮助。这是以前从未发生过的,所以我认为这是非常明显的,或者我对编码的了解还不错。无论如何,有人知道如何解决此问题吗?
在5.7中,sqlmode默认设置为:
ONLY_FULL_GROUP_BY,NO_AUTO_CREATE_USER,STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION
要删除子句ONLY_FULL_GROUP_BY,您可以这样做:
SET sql_mode=(SELECT REPLACE(@@sql_mode,'ONLY_FULL_GROUP_BY',''));
假设您需要使用非聚合列来创建该GROUP BY。
问候