您正在滥用对GROUP BY的臭名昭著的非标准MySQL扩展。标准SQL始终会拒绝您的查询,因为您所提到的列不是聚合列,而在中未提及
GROUPBY。在您的开发系统中,您正在尝试使用解决该问题
ANY_VALUE()。
在生产中,您可以关闭ONLY_FULL_GROUP_BY
MySQL模式。
尝试做这个:
SET @mode := @@SESSION.sql_mode; SET SESSION sql_mode = ''; 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
每个国家/地区将返回一行,并显示可预测的图像。



