mysql 5.6有ANY_VALUE功能吗?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了mysql 5.6有ANY_VALUE功能吗?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1473字,纯文字阅读大概需要3分钟。
内容图文
![mysql 5.6有ANY_VALUE功能吗?](/upload/InfoBanner/zyjiaocheng/891/2c320ef6880b47188b115c501d0c446e.jpg)
目前我在开发中使用mysql 5.7,在生产中使用5.6.每次我在开发中使用group运行查询时都会出现一些错误,如“错误代码: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表中返回一个随机选择的行.这种不确定性常常会给用户和您的技术支持人员带来困惑.
为什么不使查询更好,所以它选择一个特定的图像.如果您的图像表具有自动增量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 5.6有ANY_VALUE功能吗?全部内容,希望文章能够帮你解决mysql 5.6有ANY_VALUE功能吗?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。