mysql 5.6有ANY_VALUE功能吗?

时间:2016-05-07 13:47:25

标签: mysql group-by aggregate-functions mysql-error-1055

目前正在开发中使用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吗?

3 个答案:

答案 0 :(得分:16)

您可以使用MINMAX聚合函数代替ANY_VALUE

或者,您可以考虑不设置ONLY_FULL_GROUP_BY SQL模式,默认情况下为MySql 5.7设置,并且负责您与MySql 5.6的不同之处。然后,您可以延迟更新查询,直到将所有环境迁移到MySql 5.7。

这两个中哪一个是更好的选择,值得商榷,但从长远来看,最好调整您的查询,使其符合ONLY_FULL_GROUP_BY规则。使用MINMAX肯定可以用来做到这一点。

答案 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)。