mysql用any查询_mysql 5.6有ANY_VALUE功能吗?

 2023-09-11 阅读 29 评论 0

摘要:目前我在开发中使用mysql 5.7,在生产中使用5.6.每次我在开发中使用group运行查询时都会出现一些错误,如“错误代码:1055. SELECT列表的表达式#1不在GROUP BY中”这是查询.mysql性能,SELECT c.id, c.name, i.*FROM countries c, images iWHERE i.country_id = c.id

目前我在开发中使用mysql 5.7,在生产中使用5.6.每次我在开发中使用group运行查询时都会出现一些错误,如“错误代码:1055. SELECT列表的表达式#1不在GROUP BY中”

这是查询.

mysql性能,SELECT c.id, c.name, i.*

FROM countries c, images i

WHERE i.country_id = c.id

MySQL默认值?GROUP BY c.id; Fixed for 5.7;

SELECT c.id, c.name,

ANY_VALUE(i.url) url,

MySQL 查询。ANY_VALUE(i.lat) lat,

ANY_VALUE(i.lng) lng

FROM countries c, images i

mysql8.0、WHERE i.country_id = c.id

GROUP BY c.id;

为了解决这个问题,我使用5.7 ANY_VALUE中的mysql函数,但主要问题是它在mysql 5.6中不可用

MySQL binlog、因此,如果我修复sql语句进行开发,我将在生产中出错.

你知道mysql 5.6中ANY_VALUE函数的任何解决方案或polifill吗?

解决方法:

您滥用notorious nonstandard MySQL extension to GROUP BY.标准SQL将始终拒绝您的查询,因为您提到的不是聚合的列,并且在GROUP BY中未提及.在您的开发系统中,您正尝试使用ANY_VALUE()来解决这个问题.

SET @mode := @@SESSION.sql_mode;

SET SESSION sql_mode = '';

/* your query here */

SET SESSION sql_mode = @mode;

这将允许MySQL接受您的查询.

但是看,你的查询不是很正确.当你可以说服它运行时,它会从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

每个国家/地区将返回一行,并显示可预测的图像.

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

来源: https://codeday.me/bug/20190916/1807840.html

版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。

原文链接:https://hbdhgg.com/2/43287.html

发表评论:

本站为非赢利网站,部分文章来源或改编自互联网及其他公众平台,主要目的在于分享信息,版权归原作者所有,内容仅供读者参考,如有侵权请联系我们删除!

Copyright © 2022 匯編語言學習筆記 Inc. 保留所有权利。

底部版权信息