gpt4 book ai didi

mysql - mysql 5.6 是否有 ANY_VALUE 功能?

转载 作者:IT老高 更新时间:2023-10-29 00:05:37 25 4
gpt4 key购买 nike

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

这是查询。

SELECT c.id, c.name, i.* 
FROM countries c, images i
WHERE i.country_id = c.id
GROUP BY c.id; Fixed for 5.7;

SELECT c.id, c.name,
ANY_VALUE(i.url) url,
ANY_VALUE(i.lat) lat,
ANY_VALUE(i.lng) lng
FROM countries c, images i
WHERE i.country_id = c.id
GROUP BY c.id;

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

因此,如果我为开发修复 sql 语句,我将在生产中遇到错误。

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

最佳答案

您误用了 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

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

关于mysql - mysql 5.6 是否有 ANY_VALUE 功能?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37089347/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com