栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何使用only_full_group_by修复查询组

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何使用only_full_group_by修复查询组

这是MySQL用户的常见错误。在MySQL 5.7中,默认情况下,数据库会强制执行大多数其他SQL数据库多年来执行的标准语义。

规则是,选择列表中的每一列都必须是以下各项之一:

  • 在GROUP BY子句中命名;也就是说,这就是您要分组的内容。
  • 在诸如MIN,MAX(),SUM(),GROUP_CONCAT()等聚合函数中
  • 功能上取决于要分组的列(这是MySQL对标准SQL行为的扩展,而其他SQL数据库不一定支持此功能)。

在您的查询中(我将扩展您的

SELECt *
):

select user_id, feature_key, feature_value from user_featureswhere user_id = 1group by feature_key

您正在按feature_key分组,但这意味着其他列不符合我上述的规则。

这是一种解决方法:

select MAX(user_id), feature_key, GROUP_CONCAt(feature_value)from user_featureswhere user_id = 1group by feature_key

MAX(user_id)
由于WHERe子句条件可能只有一个值,因此使用起来似乎有些多余。但是也没有害处。
MIN(user_id)
也可以。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/410955.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号