当前位置: 首页 > 面试题库 >

错误代码:1055与sql_mode = only_full_group_by不兼容

胡高寒
2023-03-14
问题内容

我一直在切换到拉曼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。

问候



 类似资料: