目前正在开发中使用mysql 5.7,在生产中使用5.6。每次我在开发中使用组运行查询时都会出现一些错误,例如“错误代码:1055. SELECT列表的表达式#1不在GROUP BY中”
这是查询。
<script language="JavaScript">
var sPath=window.location.pathname;
var sPage = sPath.substring(sPath.lastIndexOf('/') + 1);
var sHost = 'host.html' ;
if(spage = sHost){
alert('orange');
}
</script>
为了解决这个问题,我使用5.7 ANY_VALUE中的mysql函数,但主要问题是它在mysql 5.6中不可用
因此,如果我修复sql语句进行开发,我将在生产中出错。
你知道mysql 5.6中ANY_VALUE函数的任何解决方案或polifill吗?
答案 0 :(得分:16)
您可以使用MIN
或MAX
聚合函数代替ANY_VALUE
。
或者,您可以考虑不设置ONLY_FULL_GROUP_BY
SQL模式,默认情况下为MySql 5.7设置,并且负责您与MySql 5.6的不同之处。然后,您可以延迟更新查询,直到将所有环境迁移到MySql 5.7。
这两个中哪一个是更好的选择,值得商榷,但从长远来看,最好调整您的查询,使其符合ONLY_FULL_GROUP_BY
规则。使用MIN
或MAX
肯定可以用来做到这一点。
答案 1 :(得分:13)
你误导了notorious nonstandard MySQL extension to GROUP BY。标准SQL将始终拒绝您的查询,因为您提到的不是聚合的列,并且在GROUP BY
中未提及。在您的开发系统中,您正尝试使用ANY_VALUE()
来解决这个问题。
在制作中,您可以关闭ONLY_FULL_GROUP_BY MySQL Mode.尝试执行this:
SET @mode := @@SESSION.sql_mode;
SET SESSION sql_mode = '';
/* your query here */
SET SESSION sql_mode = @mode;
这将允许MySQL接受您的查询。
但是看,你的查询并不正确。当你可以说服它运行时,它会从images
表中返回一个随机选择的行。这种不确定性常常会给用户和您的技术支持人员造成混淆。
为什么不让查询更好,所以它选择一个特定的图像。如果您的images
表格中包含自动增量id
列,则可以选择“第一张”图片。
SELECT c.id, c.name, i.*
FROM countries c
LEFT JOIN (
SELECT MIN(id) id, country_id
FROM images
GROUP BY country_id
) first ON c.id = first.country_id
LEFT JOIN images i ON first.id = i.id
每个国家/地区将返回一行,并显示可预测的图像。
答案 2 :(得分:4)
几十年来,您可以编写在标准SQL中无效但完全有效的mysql
的查询在标准SQL中,包含GROUP BY子句的查询无法引用 选择列表中未分配的非聚合列 GROUP BY子句。例如,此查询在标准SQL中是非法的 因为选择列表中的非聚合名称列不会 出现在GROUP BY:
SELECT o.custid,c.name,MAX(o.payment)FROM订购AS o,客户 as c WHERE o.custid = c.custid GROUP BY o.custid;对于查询 合法,名称列必须从选择列表中删除或 在GROUP BY子句中命名。
MySQL扩展了GROUP BY的标准SQL使用,以便选择列表 可以引用GROUP BY子句中未命名的非聚合列。
这来自GROUP BY上的Mysql 5.6手册页面。如果您查看5.7.6的同一页面,您会发现事情已经发生了变化。并且发生了巨大变化!
该页面也为您提供了解决方案。禁用ONLY_FULL_GROUP_BY
这将使您的旧5.6查询可以在5.7.6上运行(从查询中删除ANY_VALUE,因为它在5.7.6中不可用,而是使用ONLY_FULL_GROUP_BY)。